ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

【总结】动态规划的具体路径输出

2022-07-26 10:03:59  阅读:115  来源: 互联网

标签:总结 输出 循环法 int 路径 dfs 倒序


【总结】动态规划的具体路径输出

一、解决的问题

在取得了动态规划的极值或最优解之后,要求输出具体的路径。

二、解决思路

反向查找转移路径,从最后状态出发,检查所有前序状态,看看是从哪个状态转移过来的,一直到出发点为止。

\(dfs\)法,路径是反的,需要倒序输出。

倒序循环法,没有这个问题,可以正序输出。

三、倒序循环法 【推荐】

int j = m;                       // j开始枚举每个可用空间
for (int i = n; i >= 1; i--)     // 倒序遍历dp数组
    for (int k = 0; k <= j; k++) // f[i][j]是从哪个前序状态f[i-1][?]转移而来
        if (f[i][j] == f[i - 1][j - k] + w[i][k]) {
            path[i] = k; //记录路径
            j -= k;      //减少体积
            break;       //找到一组即可
        }
//输出路径
for (int i = 1; i <= n; i++) printf("%d %d\n", i, path[i]);

四、\(dfs\)法

//反向查找转移路径:dfs法
int path[N], idx, id;
void dfs(int i, int j) {
    if (i == 0) return;
    for (int k = 0; k <= j; k++) {
        if (f[i - 1][j - k] + w[i][k] == f[i][j]) {
            path[++idx] = k;
            dfs(i - 1, j - k);
            return;
        }
    }
}

//调用
dfs(n, m);
for (int i = idx; i; i--) printf("%d %d \n", ++id, path[i]);

标签:总结,输出,循环法,int,路径,dfs,倒序
来源: https://www.cnblogs.com/littlehb/p/16519767.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有