6 2 3 1 3 5 1 4 7 2 8 12 3 8 4 4 9 12 9 10 2 1 2 8 9 10
9
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int INF=0x3f3f3f3f;
const int N=1000+10;
int S,T,D,n;
int e[N][N],d[N],v[N];
int ss[N],dd[N];
void Dijkstra()
{
memset(d,0x3f,sizeof(d));
memset(v,0,sizeof(v));
for(int i=0;i<=S;i++) //思路是令多个起点的初始路径为0
d[ss[i]]=0;
for(int i=1;i<=n;i++)
{
int m=INF,x;
for(int y=1;y<=n;y++)
if(!v[y]&&d[y]<=m) m=d[x=y];
v[x]=1;
for(int y=1;y<=n;y++)
if(d[y]>d[x]+e[x][y]) d[y]=d[x]+e[x][y];
}
}
int main()
{
while(scanf("%d%d%d",&T,&S,&D)==3)
{
memset(e,0x3f,sizeof(e));
n=0;
for(int i=1;i<=T;i++)
{
int p,q,w;
scanf("%d%d%d",&p,&q,&w);
if(e[q][p]>w)
e[p][q]=e[q][p]=w;
n=max(n,p);
n=max(n,q);
}
for(int i=1;i<=S;i++)
scanf("%d",&ss[i]);
for(int i=1;i<=D;i++)
scanf("%d",&dd[i]);
int m=INF;
for(int j=1;j<=D;j++)
{
Dijkstra();
if(d[dd[j]]<m) //比较得到最短时间。
m=d[dd[j]];
}
printf("%d\n",m);
}
return 0;
}
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int INF=0x3f3f3f3f;
const int N=1000+10;
int S,T,D,n;
int e[N][N],d[N],v[N];
int ss[N],dd[N];
int Dijkstra()
{
memset(d,0x3f,sizeof(d));
memset(v,0,sizeof(v));
d[0]=0;
for(int i=0;i<=n;i++)
{
int m=INF,x;
for(int y=0;y<=n;y++)
if(!v[y]&&d[y]<=m) m=d[x=y];
v[x]=1;
for(int y=0;y<=n;y++)
if(d[y]>d[x]+e[x][y]) d[y]=d[x]+e[x][y];
}
}
int main()
{
while(scanf("%d%d%d",&T,&S,&D)==3)
{
memset(e,0x3f,sizeof(e));
n=0;
int i;
for(i=1;i<=T;i++)
{
int p,q,w;
scanf("%d%d%d",&p,&q,&w);
if(e[q][p]>w)
e[p][q]=e[q][p]=w;
n=max(n,p);
n=max(n,q);
}
for(i=1;i<=S;i++)
{
scanf("%d",&ss[i]);
e[0][ss[i]]=e[ss[i]][0]=0; //再与领近的城市连一条权值为0的路
}
for(int i=1;i<=D;i++)
scanf("%d",&dd[i]);
int m=INF,ans;
Dijkstra();
for(int j=1;j<=D;j++)
{
ans=d[dd[j]];
if(ans<m)
m=ans;
}
printf("%d\n",m);
}
return 0;
}
HDU 2066 一个人的旅行.,布布扣,bubuko.com
原文:http://blog.csdn.net/darwin_/article/details/24500987