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

codevs 2596 售货员的难题

时间:2016-01-03 17:26:07      阅读:110      评论:0      收藏:0      [点我收藏+]

标签:

这题卡空间,只好用dfs。。。加个最短路优(乱)化(搞):当前距离与下一个点的距离与下一个点到终点的最短路之和大于ans则直接剪掉。

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int n,map[20][20],ans=12345678;
int d[20][20];
bool vis[20];
void dfs(int x,int dis,int cnt)
{
if ((x==1) && (cnt==n))
{
ans=min(ans,dis);
return;
}
vis[x]=true;
for (int i=1;i<=n;i++)
{
if ((dis+map[x][i]+d[i][1]<ans) && ((vis[i]==false) || ((i==1) && (cnt==n-1))))
dfs(i,dis+map[x][i],cnt+1);
}
vis[x]=false;
}
int main()
{
memset(vis,false,sizeof(vis));
scanf("%d",&n);
for (int i=1;i<=n;i++)
for (int j=1;j<=n;j++)
scanf("%d",&map[i][j]);
for (int i=1;i<=n;i++)
for (int j=1;j<=n;j++)
d[i][j]=map[i][j];
for (int k=1;k<=n;k++)
for (int i=1;i<=n;i++)
for (int j=1;j<=n;j++)
if (d[i][j]>d[i][k]+d[k][j])
d[i][j]=d[i][k]+d[k][j];
dfs(1,0,0);
printf("%d\n",ans);
return 0;
}

codevs 2596 售货员的难题

标签:

原文地址:http://www.cnblogs.com/ziliuziliu/p/5096469.html

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