116 - Unidirectional TSP(DP)

原创 2015年07月10日 21:14:31

多段图的最短路问题 。  运用了很多的技巧 :如 记录字典序最小路径 。

细节参见代码:

#include<bits/stdc++.h>
using namespace std;
const int INF = 2000000000;
int m,n,a[15][105],d[15][105],next_[15][105];
int main() {
    while(~scanf("%d%d",&m,&n)) {
        for(int i=0;i<m;i++)
            for(int j=0;j<n;j++) scanf("%d",&a[i][j]);
        int ans = INF,first = 0;
        for(int j=n-1;j>=0;j--) {
            for(int i=0;i<m;i++) {
                if(j == n-1) d[i][j] = a[i][j]; //边界
                else {
                    int rows[3] = {i,i-1,i+1};
                    if(i==0) rows[1] = m-1;
                    if(i==m-1) rows[2] = 0;
                    sort(rows,rows+3);    //重新排序,以便找到字典序最小的
                    d[i][j] = INF;
                    for(int k=0;k<3;k++) {
                        int v = d[rows[k]][j+1] + a[i][j];
                        if(v < d[i][j]) { d[i][j] = v; next_[i][j] = rows[k]; }
                    }
                }
                if(j==0&&d[i][j]<ans) { ans = d[i][j]; first = i; } //在最后一列确定最大值以及第一列的行数答案
            }
        }
        printf("%d",first+1);
        for(int i=next_[first][0],j=1;j<n;i=next_[i][j],j++) printf(" %d",i+1);
        printf("\n%d\n",ans);
    }
    return 0;
}


版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

UVa 116 - Unidirectional TSP(dp)

题意:找最短路,知道三种行走方式,给出图,求出一条从左边到右边的最短路,且字典序最小。 用dp记忆化搜索的思想来考虑是思路很清晰的,但是困难在如何求出字典序最小的路。 因为左边到右边的字典序最小就...

UVa 116:Unidirectional TSP(DP)

题目链接:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=847&page=show_pr...

UVA - 116 Unidirectional TSP(dp+多段图的最短路)

题意: 给一个n行m列的整数矩阵,从第一列任何一个位置出发每次往右、右上或右下走一格,最终到达最后一列。要求经过的整数之和最小。整个矩阵是环形的,即第一行的上一行是最后一行,最后一行的下一行是第一行...

例题9-4 UVa116 Unidirectional TSP(DP:多段图的最短路)

题意: 看白书 要点: 一共三种决策:直行,右上,右下。那么就递推,注意题目中可以从第一列的任意一行出发,而且是环形的,最后还得按字典序输出路径,路径输出就直接用数组记录,因为是倒序递推,所以正...

UVA 116 Unidirectional TSP 经典dp题

题意:找最短路,知道三种行走方式,给出图,求出一条从左边到右边的最短路,且字典序最小。 用dp记忆化搜索的思想来考虑是思路很清晰的,但是困难在如何求出字典序最小的路。 因为左边到右边的字典序最小就...
  • hcbbt
  • hcbbt
  • 2013年09月21日 10:35
  • 3021

DP--UVA - 116 Unidirectional TSP

Description Background Problems that require minimum paths through some domain appear in m...

UVa 116 Unidirectional TSP (DP)

116 - Unidirectional TSP Time limit: 3.000 seconds http://uva.onlinejudge.org/index.php?option=com_...

116 - Unidirectional TSP 【DP】

题目大意 样例 input output 解释 思路 代码 Hit题目大意传送门 样例input5 6 3 4 1 2 8 6 6 1 8 2 7 4 5 9 3 ...

UVa 116 Unidirectional TSP(DP)

ji

UVA - 116 - Unidirectional TSP (简单DP + 打印路径)

题目传送: UVA - 116 思路:可以定义状态为dp[i][j] 为从第i行第j列开始往后走到第n列(总共n列)的最小值(赋初始值为无穷),且状态方程很好推出来:dp[i][j]...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:116 - Unidirectional TSP(DP)
举报原因:
原因补充:

(最多只允许输入30个字)