一道编程题(有答案,但是我看不懂)

给你一个数字三角形,形式如下:12345678910找出从第一层到最后一层的一条路,使得所经过的权值之和最小或者最大.无论对与新手还是老手,这都是再熟悉不过的题了,很容易... 给你一个数字三角形, 形式如下:
1
2 3
4 5 6
7 8 9 10
找出从第一层到最后一层的一条路,使得所经过的权值之和最小或者最大.
无论对与新手还是老手,这都是再熟悉不过的题了,很容易地,我们写出状态转移方程:f(i, j)=a[i, j] + min{f(i+1, j),f(i+1, j + 1)}

麻烦解释一下f(i, j)=a[i, j] + min{f(i+1, j),f(i+1, j + 1)}
的意义吧,谢谢!
展开
 我来答
fhydralisk
2009-04-11 · TA获得超过1854个赞
知道小有建树答主
回答量:1088
采纳率:0%
帮助的人:620万
展开全部
这是一道动态规划问题,建议zzy首先阅读动态规划相关内容。
公式的意思是我们通过逐行(从上至下)递推能够得到从最上方的“1”开始到第i+1行第j+1列权值之和的最小值f(i,j)为a[i, j] + min{f(i+1, j),f(i+1, j + 1),其中a[i,j]代表数字三角形中第i行第j列的权值。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式