博客
关于我
数字三角形问题(动态规划)
阅读量:801 次
发布时间:2019-03-25

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

今天,我尝试解决了一个关于数字三角形的算法问题,目标是找到从三角形顶部到底层的路径,使得路径上的数字之和最大。这个过程让我深入了解了动态规划的应用,特别是在分治问题中的模拟思维方式。

在这个问题中,最优子结构在动态规划中发挥了重要作用。每一个节点到达底层的最优路径,都包含在它自身到达底层的最优子路径上。这意味着从上到下的每一个节点,其最优路径都必须经过它下方节点的最优路径选择。

状态转移方程为:t(i,j) = w(i,j) + max(t(i+1,j), t(i+1,j+1))。这意味着从第i层第j个节点到底层的最长路径长度,等于该节点的权值加上它下方两个节点中最大的那个节点的最长路径长度。这一状态转移方程确保了路径选择的最优性,因为它总是选择当前路径延伸时的最大收益。

在实现方面,这个问题可以通过从下向上的动态规划来解决。用一个二维数组存储数据,tri[i][j]表示第i层第j个节点的数据。初始时,二维数组中的值为题目给定的数字。接着,顺序地从第n-2层开始,计算每一层所有节点的最大路径值,这样确保在计算当前层的节点时,已经知道了下一层的计算结果。

代码实现可以如下:

int i, j;    for(i = n-2; i >= 0; i--){        for(j = 0; j <= i; j++){            a[i][j] += max(a[i+1][j], a[i+1][j+1]);        }    }    return a[0][0];}

这个代码的时间复杂度为O(n²),在n较大的情况下也能保持较好的性能。一开始可能会对代码中的轮动循环不太直观,但仔细分析后,其逻辑是清晰且巧妙的。

通过分析和实践,我理解到,动态规划的核心在于分解问题,将大问题分解为更小的子问题。每一个子问题都有自己的解,而这些子问题的解又可以组合起来得到最终的答案。在这个问题中,我们从底层向上逐步填充每一个节点的值,确保了每一步都选择了最大的可能值,从而保证了路径和的最大化。

总的来说,这个问题让我对动态规划在路径问题中的应用有了更深入的认识。理解这一点后,我能更自信地应用这种方法来解决类似的问题,甚至在更复杂的路径选择问题中寻找灵感。

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

你可能感兴趣的文章
mysql8.0新特性-自增变量的持久化
查看>>
Mysql8.0注意url变更写法
查看>>
Mysql8.0的特性
查看>>
MySQL8修改密码报错ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
查看>>
MySQL8修改密码的方法
查看>>
Mysql8在Centos上安装后忘记root密码如何重新设置
查看>>
Mysql8在Windows上离线安装时忘记root密码
查看>>
MySQL8找不到my.ini配置文件以及报sql_mode=only_full_group_by解决方案
查看>>
mysql8的安装与卸载
查看>>
MySQL8,体验不一样的安装方式!
查看>>
MySQL: Host '127.0.0.1' is not allowed to connect to this MySQL server
查看>>
Mysql: 对换(替换)两条记录的同一个字段值
查看>>
mysql:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法
查看>>
MYSQL:基础——3N范式的表结构设计
查看>>
MYSQL:基础——触发器
查看>>
Mysql:连接报错“closing inbound before receiving peer‘s close_notify”
查看>>
mysqlbinlog报错unknown variable ‘default-character-set=utf8mb4‘
查看>>
mysqldump 参数--lock-tables浅析
查看>>
mysqldump 导出中文乱码
查看>>
mysqldump 导出数据库中每张表的前n条
查看>>