一个人的旅行
Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 15334 Accepted Submission(s): 5211
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个数,表示草儿想去地方。
接着有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
Author
Grass
Source
Recommend
import java.util.Arrays; import java.util.Scanner; public class Main{ static int MAX=100000000,map[][],D,end[]; public static void main(String[] args) { Scanner input=new Scanner(System.in); while(input.hasNext()){ int t=input.nextInt(); int s=input.nextInt(); D=input.nextInt(); map=new int[1005][1005]; for(int i=1;i<=1000;i++) Arrays.fill(map[i], MAX); for(int i=0;i<t;i++){ int a=input.nextInt(); int b=input.nextInt(); int c=input.nextInt(); if(map[a][b]>c) map[a][b]=map[b][a]=c; } int from[]=new int[s]; for(int i=0;i<s;i++) from[i]=input.nextInt(); end=new int[D]; for(int i=0;i<D;i++){ end[i]=input.nextInt(); } int max=MAX; /*for(int i=1;i<=10;i++){ for(int j=1;j<=10;j++) System.out.print(map[i][j]+" "); System.out.println(); }*/ for(int i=0;i<s;i++){ int ss=dij(from[i]); //System.out.println("*******"+ss); if(max>ss){ max=ss; } } System.out.println(max); } } private static int dij(int v) { boolean vis[]=new boolean[1005]; int d[]=new int[1005]; for(int i=1;i<=1000;i++){ vis[i]=false; d[i]=map[v][i]; } vis[v]=true; d[v]=0; int x=0; int min; for(int i=1;i<=1000;i++){ min=MAX; for(int j=1;j<=1000;j++){ if(!vis[j]&&min>d[j]){ x=j; min=d[j]; } } vis[x]=true; if(min==MAX) break; for(int j=1;j<=1000;j++){ if(!vis[j]&&d[j]>d[x]+map[x][j]){ d[j]=d[x]+map[x][j]; } } } min=MAX; // System.out.println("##############"+D); for(int i=0;i<D;i++){ //System.out.println("-----"+d[i]); if(min>d[end[i]]) min=d[end[i]]; } return min; } }
作者:u010103075 发表于2013-11-22 23:14:12 原文链接
阅读:68 评论:0 查看评论