博客
关于我
数塔取数问题
阅读量:281 次
发布时间:2019-03-01

本文共 1589 字,大约阅读时间需要 5 分钟。

为了解决这个问题,我们需要找到从数塔顶端走到底面的路径,使得经过的数字之和最大。每次只能向下走到下一层的相邻位置。我们可以使用动态规划来解决这个问题。

方法思路

  • 问题分析:我们需要从数塔的顶端开始,每次只能向下移动到下一层的相邻位置,找到经过的数字之和的最大值。这个问题可以通过动态规划来解决,因为每一步的选择会影响后续的选择。

  • 动态规划建模:我们使用一个二维数组 dp,其中 dp[i][j] 表示到达第 i 层第 j 个位置时的最大和。我们从第一层开始,逐层填充这个数组。

  • 初始化:第一层只有一个数字,所以 dp[1][1] 初始化为该数字。

  • 填充动态规划数组:对于每一层 i,我们处理每个位置 j

    • 如果是第一层,只能从上一层的 j=1位置来。
    • 如果是最后一层,只能从上一层的 j=i位置来。
    • 其他位置可以从上一层的 j= j-1 和 j= j位置来,取较大的那个加上当前数字。
  • 结果:最后一层的所有位置中的最大值即为答案。

  • 解决代码

    #include 
    #include
    #include
    using namespace std;int main() { int n, N; scanf("%d", &n); N = n; vector
    > a(N + 1, vector
    (N + 1)); for (i = 1; i <= N; ++i) { vector
    row; while (row.size() < i) { char c; do scanf("%c", &c); while (c == ' '); if (c == '\n') break; row.push_back(c - ' '); } for (j = 1; j <= i; ++j) scanf("%d", &a[i][j]); } vector
    > dp(N + 1, vector
    (N + 1)); dp[1][1] = a[1][1]; for (i = 2; i <= N; ++i) { for (j = 1; j <= i; ++j) { if (j == 1) { dp[i][j] = a[i][j] + dp[i-1][j]; } else if (j == i) { dp[i][j] = a[i][j] + dp[i-1][j]; } else { dp[i][j] = a[i][j] + max(dp[i-1][j-1], dp[i-1][j]); } } } int max_val = 0; for (j = 1; j <= N; ++j) { if (dp[N][j] > max_val) { max_val = dp[N][j]; } } cout << max_val << endl; return 0;}

    代码解释

  • 读取输入:首先读取高度 N,然后读取每一层的数字,存储在二维数组 a 中。
  • 初始化动态规划数组dp[1][1] 初始化为第一层的数字。
  • 填充动态规划数组:从第二层开始,逐层计算每个位置的最大和,根据上一层的结果进行计算。
  • 计算结果:最后一层所有位置的最大值即为答案,打印出来。
  • 这个方法通过动态规划有效地解决了问题,确保了每一步的选择都是最优的,从而保证了最终结果的正确性。

    转载地址:http://xfho.baihongyu.com/

    你可能感兴趣的文章
    Openlayers高级交互(18/20):根据feature,将图形适配到最可视化窗口
    查看>>
    Openlayers高级交互(19/20): 地图上点击某处,列表中显示对应位置
    查看>>
    Openlayers高级交互(2/20):清除所有图层的有效方法
    查看>>
    Openlayers高级交互(20/20):超级数据聚合,页面不再混乱
    查看>>
    Openlayers高级交互(3/20):动态添加 layer 到 layerGroup,并动态删除
    查看>>
    Openlayers高级交互(4/20):手绘多边形,导出KML文件,可以自定义name和style
    查看>>
    Openlayers高级交互(5/20):右键点击,获取该点下多个图层的feature信息
    查看>>
    Openlayers高级交互(6/20):绘制某点,判断它是否在一个电子围栏内
    查看>>
    Openlayers高级交互(7/20):点击某点弹出窗口,自动播放视频
    查看>>
    Openlayers高级交互(8/20):选取feature,平移feature
    查看>>
    Openlayers高级交互(9/20):编辑图形(放缩、平移、变形、旋转),停止编辑
    查看>>
    Openlayers:DMS-DD坐标形式互相转换
    查看>>
    openlayers:圆孔相机根据卫星经度、纬度、高度、半径比例推算绘制地面的拍摄的区域
    查看>>
    OpenLDAP(2.4.3x)服务器搭建及配置说明
    查看>>
    OpenLDAP编译安装及配置
    查看>>
    Openmax IL (二)Android多媒体编解码Component
    查看>>
    OpenMCU(一):STM32F407 FreeRTOS移植
    查看>>
    OpenMCU(三):STM32F103 FreeRTOS移植
    查看>>
    OpenMCU(三):STM32F103 FreeRTOS移植
    查看>>
    OpenMCU(二):GD32E23xx FreeRTOS移植
    查看>>