码迷,mamicode.com
首页 > 其他好文 > 详细

116 - Unidirectional TSP(DP)

时间:2015-07-10 22:19:35      阅读:207      评论:0      收藏:0      [点我收藏+]

标签:acm   uva   

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

细节参见代码:

#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;
}


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

116 - Unidirectional TSP(DP)

标签:acm   uva   

原文地址:http://blog.csdn.net/weizhuwyzc000/article/details/46835095

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!