c#如何实现数字三角形
发表于:2025-11-07 作者:千家信息网编辑
千家信息网最后更新 2025年11月07日,小编给大家分享一下c#如何实现数字三角形,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!数字三角形问题。有一个由非负数组成的
千家信息网最后更新 2025年11月07日c#如何实现数字三角形
小编给大家分享一下c#如何实现数字三角形,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
数字三角形问题。有一个由非负数组成的三角形,如图所示。
从第一行开始,每次可以往左下或者右下走一格,直到走到最下行,把沿途经过的数全部加起来,如何走才能使得这个和最大?
我们最常规的想法:就是利用回溯发,将每一条路径都遍历一遍,然后选出最长的路径。
此题更高效的算法是动态规划。把当前位置(i,j)看成一个状态,然后定义指标函数d(i,j)为从格子(i,j)出发的能得到的最大的和(包括次格子本身),那么本题就转化成了求d(1,1)。
在动态规划的题目里,状态转移方程无疑是非常重要的,下面我们来看看状态转移方程d(i,j)=a(i,j)+max{d(i+1,j),d(i+1,j+1)}其中a(i,j)表示每个圆形的数字
下面给出代码
#include#include using namespace std;int value[4][4];int dp[4][4];int main(){ for(int i=0;i<4;i++) { for(int j=0;j<=i;j++) cin>>value[i][j]; } for(int i=0;i<4;i++) dp[3][i]=value[3][i]; for(int i=2;i>=0;i--) for(int j=0;j<=i;j++) dp[i][j]=value[i][j]+max(dp[i+1][j],dp[i+1][j+1]); cout< 以上是"c#如何实现数字三角形"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!
三角形
数字
三角
状态
篇文章
c#
最大
内容
动态
方程
格子
路径
规划
最长
重要
一行
不怎么
代码
位置
函数
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
清丰软件开发项目管理
杭州大唐网络技术有限公司
嘉峪关软件开发
移动应用软件开发csdn
手机无法找到服务器
网络安全部周
外贸软件服务器
网络安全意识的预期成果
服务器并发数计算
服务器公网ip与私网ip
2017网络安全宣传手册
什么是入数据库
数据库备份数据不可用
嘉兴智帮互联网科技有限公司待遇
服务器防火墙安全检查总结
云服务器密码怎么设置安全
商品销售管理数据库报告
中华人民大学数据库系统概论
怎么搭建socks5代理服务器
次时代软件开发
绝地求生服务器频繁忙
中国工商银行西安软件开发
vb显示采集数据库
集群服务器安全性
数据库怎么建立视图
服务器主机风扇一直转
cf登录老是服务器连接失败
硕士软件开发
服务器热备什么意思
数据库 完整性