zufeoj_售货员的难题

题目链接:http://acm.ocrosoft.com/problem.php?cid=1222&pid=34


售货员的难题

时间限制: 5 Sec   内存限制: 128 MB
提交: 19   解决: 6
[ 提交][ 状态][ 讨论版][命题人: 外部导入]

题目描述

某乡有n个村庄( 1 < n < 20 ),有一个售货员,他要到各个村庄去售货,各村庄之间的路程s(0 < s < 1000 )是已知的,且A村到B村与B村到A村的路大多不同。为了提高效率,他从商店出发到每个村庄一次,然后返回商店所在的村,假设商店所在的村庄为1,他不知道选择什么样的路线才能使所走的路程最短。请你帮他选择一条最短的路。 


3 {村庄数} 
0 2 1 {村庄1到各村的路程} 
1 0 2 {村庄2到各村的路程} 
2 1 0 {村庄3到各村的路程} 

输入

村庄数n和各村之间的路程(均是整数)。 

输出

最短的路程。 
问题的原型就是:哈密顿回路。天文学家哈密顿(William Rowan Hamilton) 提出,在一个有多个城市的地图网络中,寻找一条从给定的起点到给定的终点沿 途恰好经过所有其他城市一次的路径。这个问题和著名的过桥问题的不同之处在于,某些城市之间的旅行不 一定是双向的。比如A→B,但B→A是不允许的。

样例输入

3
0 2 1
1 0 2
2 1 0

样例输出

3


用一个过程road(step,x:longint)来描述走的状况,其中step是当前已到村庄数、x是当前所在的村庄。如果step=n,下面只能回起点了,直接看第x个村庄到第一个村庄的路程加上已走的总路程,如果比最小值还小则替换最小值(要保存路径的话也可保存,这是回溯算法的优点,考虑到达最小值的路径可能不止一条,不便于测试,题目没要求输出路径)。如果step还小于n,那么将还没有到过的村庄一个一个地试过去,再调用下一步road(step+1,新到的村庄号)。 


#include<bits/stdc++.h>
using namespace std;
int n;
vector<int>p[22];
bool vis[22];
int mp[22][22];
int ans;
void dfs(int x,int step,int sum){
    if(step==n){
        ans=min(ans,sum+mp[x][0]);
        return;
    }
    for(int i=0;i<p[x].size();i++){
        //剪枝 
        if(vis[p[x][i]]==0&&sum+mp[x][p[x][i]]<ans){
            vis[p[x][i]]=1;
            dfs(p[x][i],step+1,sum+mp[x][p[x][i]]);
            vis[p[x][i]]=0;
        }
    }
}
int main(){
    while(cin>>n)
    {
        for(int i=0;i<n;i++)
        p[i].clear();
        ans=99999999;
        for(int i=0;i<n;i++)
        {
            for(int j=0;j<n;j++)
            {
                cin>>mp[i][j];
                if(i!=j)
                {
                    p[i].push_back(j);
                }
            }
        }
        memset(vis,0,sizeof(vis));
        vis[0]=1;
        dfs(0,1,0);
        cout<<ans<<endl;
    }
    return 0;
}

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值