设为首页
收藏本站
开启辅助访问
切换到窄版
登录
立即注册
中问网首页
我的收藏
站长博客
搜索
搜索
本版
帖子
用户
第一问答网
»
论坛
›
中问网
›
问答
›
求解动态规划法拾取杂物问题(c语言)
返回列表
发新帖
求解动态规划法拾取杂物问题(c语言)
[复制链接]
11
|
1
|
2011-3-17 11:25:51
|
显示全部楼层
|
阅读模式
给定一个二维数组a[m][n],任意a
[j]上有不同给定数目的杂物。起点a[0][0],要求只能向前不能后退(即i,j只能),要求用动态规划的算法求出拾取杂物最多的行进路线
不要求给出具体代码,只说说大概的求解思路就好(尤其是子问题的推导……)
回复
使用道具
举报
千问
|
2011-3-17 11:25:51
|
显示全部楼层
<pre id=\"best-answer-content\" class=\"reply-text mb10\">代码在百度表示太混乱了,我说说我的做法吧
对于每个节点啊a
[j],它必定来自a[i-1][j]或a
[j-1],那么对于每个节点只要设一个同样大的数组的b
[j]节点记录max{b[i-1][j],b
[j-1]} a
[j]
那么核心算法可以这样表示
for(i=1;i=k;i)
{
for(j=1;j=k;j)
{
if(b[i-1][j][0]b
[j-1][0])
{
b
[j][0]=b[i-1][j][0] a
[j];
b
[j][1]=0;
//表示选择上面路径
}
else
{
b
[j][0]=b
[j-1][0] a
[j];
b
[j][1]=1;
//表示选择右边路径
}
}
}
还有说明,把数组设大点,把b
[0][0]和b[0]
[0]都设为0就可以节省判断边缘的时间
这样最后的b[i-1][j-1][0]一定就是最大值了
然后从b[i-1][j-1][1]一路回溯到起点就能找出路径了
回复
使用道具
举报
返回列表
发新帖
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
立即注册
本版积分规则
发表回复
回帖后跳转到最后一页
千问
主题
0
回帖
4882万
积分
论坛元老
论坛元老, 积分 48824836, 距离下一级还需 -38824837 积分
论坛元老, 积分 48824836, 距离下一级还需 -38824837 积分
积分
48824836
加好友
发消息
回复楼主
返回列表
问答
热门排行