c#如何实现数字三角形
发表于:2025-01-19 作者:千家信息网编辑
千家信息网最后更新 2025年01月19日,小编给大家分享一下c#如何实现数字三角形,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!数字三角形问题。有一个由非负数组成的
千家信息网最后更新 2025年01月19日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安全错误
数据库的锁怎样保障安全
应用软件开发客户关系
苏州机械软件开发售后服务
中国结算总部软件开发有外包嘛
网络技术手写笔记
下载安全连接到服务器
人大金仓数据库数据迁移
国家对网络安全的应急演练
服务器cpu如何检测
超微服务器进不去pxe
根据下拉菜单显示不同数据库
winmail邮件服务器
密码编码学与网络安全视频
银行服务器数据丢失
网络技术 证书
如何做虚拟服务器
跟随网络技术
数据通信与网络技术知识
虹口区提供数据库系统研发协议
江西共青团网络安全教育课
网络技术专业毕业设计网站
获取不同平台数据库元数据
问道手游如何看服务器
贵州综合网络安全工程介绍
上海思霍网络技术
暗黑二都有什么服务器
境外域名服务器
软件开发开发软件
网络安全工程师工作经历
联想小型服务器
软件开发集市