hdu-2066(Dijkstra)
一個人的旅行
Time Limit : 1000/1000ms (Java/Other)???Memory Limit : 32768/32768K (Java/Other)
Total Submission(s) : 18???Accepted Submission(s) : 16
Problem Description
雖然草兒是個路癡(就是在杭電待了一年多,居然還會在校園里迷路的人,汗~),但是草兒仍然很喜歡旅行,因為在旅途中 會遇見很多人(白馬王子,^0^),很多事,還能豐富自己的閱歷,還可以看美麗的風景……草兒想去很多地方,她想要去東京鐵塔看夜景,去威尼斯看電影,去陽明山上看海芋,去紐約純粹看雪景,去巴黎喝咖啡寫信,去北京探望孟姜女……眼看寒假就快到了,這么一大段時間,可不能浪費啊,一定要給自己好好的放個假,可是也不能荒廢了訓練啊,所以草兒決定在要在最短的時間去一個自己想去的地方!因為草兒的家在一個小鎮上,沒有火車經過,所以她只能去鄰近的城市坐火車(好可憐啊~)。
?
?
Input
輸入數據有多組,每組的第一行是三個整數T,S和D,表示有T條路,和草兒家相鄰的城市的有S個,草兒想去的地方有D個; 接著有T行,每行有三個整數a,b,time,表示a,b城市之間的車程是time小時;(1=<(a,b)<=1000;a,b 之間可能有多條路) 接著的第T+1行有S個數,表示和草兒家相連的城市; 接著的第T+2行有D個數,表示草兒想去地方。
?
?
Output
輸出草兒能去某個喜歡的城市的最短時間。
?
?
Sample Input
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
?
?
Sample Output
9
用0來表示家 到附近的城市的距離為0 用一次Dijkstra即可。
#include<bits/stdc++.h> using namespace std; const int INF = 0x3f3f3f3f; const int maxn = 1010; int a[maxn][maxn],dis[maxn]; bool vis[maxn]; int T,S,D,n; void init() {for(int i=0;i<maxn;i++)for(int j=0;j<maxn;j++)if(i==j) a[i][j] = 0;else a[i][j] = INF;return ; } void Dijkstra() {memset(vis,0,sizeof(vis));vis[0]=1;for(int i=0;i<=n;i++)dis[i]=a[0][i];for(int i=1;i<=n;i++){int minn=INF,pos;for(int j=1;j<=n;j++){if(!vis[j]&&dis[j]<minn){pos=j;minn=dis[j];}}vis[pos]=true;for(int j=1;j<=n;j++){if(dis[pos]+a[pos][j]<dis[j]&&!vis[j])dis[j]=dis[pos]+a[pos][j];}}return ; } int main() {while(~scanf("%d%d%d",&T,&S,&D)){n=0;init();int x,y,z;while(T--){scanf("%d%d%d",&x,&y,&z);n=max(max(n,x),y);if(z<a[x][y]) a[x][y]=a[y][x]=z;}while(S--){scanf("%d",&x);a[0][x]=a[x][0]=0;}Dijkstra();int mini=INF;for(int i=0;i<D;i++){scanf("%d",&x);mini=min(mini,dis[x]);}printf("%d\n",mini);}return 0; }?
與50位技術專家面對面20年技術見證,附贈技術全景圖總結
以上是生活随笔為你收集整理的hdu-2066(Dijkstra)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: JMS学习十 ActiveMQ支持的传
- 下一篇: jsp九大内置对象与servlet中ja