zoukankan      html  css  js  c++  java
  • HDU 2066 一个人的旅行

    虽然草儿是个路痴(就是在杭电待了一年多,居然还会在校园里迷路的人,汗~),但是草儿仍然很喜欢旅行,因为在旅途中 
    会遇见很多人(白马王子,^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

    这题真心没啥难点,连重边都提醒了,数据还不大,用邻接矩阵都能过。

    so 直接上代码:

    #include<stdio.h>
    #include<iostream>
    #include<queue>
    #include<cstring>
    #include<cmath>
    #include<vector>
    
    #define INF 0x3f3f3f3f
    
    using namespace std;
    
    int T,S,D;
    int map[1005][1005];
    bool mark[1005];
    int SS[1005];
    int DD[1005];
    int len[1005];
    
    int  Spfa(int s)
    {
    	memset(len,INF,sizeof(len));
    	len[s] = 0;
    	queue<int>Q;
    	Q.push(s);
    	mark[s] = true;
    	while(!Q.empty())
    	{
    		int mid = Q.front();
    		Q.pop();
    		mark[mid] = false;
    		for(int i=1 ; i<=1000 ; i++)
    		{
    			if(len[i]>len[mid]+map[mid][i])
    			{
    				len[i] = len[mid]+map[mid][i];
    				if(!mark[i])
    				{
    					Q.push(i);
    					mark[i] = true;
    				}
    			}
    		}
    	}
    }
    
    int main()
    {
    	while(scanf("%d %d %d",&T,&S,&D)!=EOF)
    	{
    		int min = INF;
    		memset(map,INF,sizeof(map));
    		while(T--)
    		{
    			int a,b,c;
    			scanf("%d %d %d",&a,&b,&c);
    			if(map[a][b]>c)map[a][b] = map[b][a] = c;
    		}
    		for(int i=0 ; i<S ; i++)
    		{
    			scanf("%d",&SS[i]);
    		}
    		for(int i=0 ; i<D ; i++)
    		{
    			scanf("%d",&DD[i]);
    		}
    		for(int i=0 ; i<S ; i++)
    		{
    			Spfa(SS[i]);
    			for(int j=0 ; j<D ; j++)
    			{
    				if(len[DD[j]]<min)min = len[DD[j]];
    			}
    		}
    		printf("%d
    ",min);	
    	}
    	return 0;
    }


  • 相关阅读:
    【276】◀▶ Python 字符串函数说明
    Spring事务配置的五种方式 巨全!不看后悔,一看必懂!
    Android Developers:两个视图渐变
    《Linux命令行与shell脚本编程大全》 第二十七章 学习笔记
    Android的TextView与Html相结合的用法
    嵌入式C语言优化小技巧
    vxworks获取系统时间编程
    【算法与数据结构】在n个数中取第k大的数(基础篇)
    字符集转换 字符类型转换 utf-8 gb2312 url
    java 从零开始,学习笔记之基础入门<Oracle_基础>(三十三)
  • 原文地址:https://www.cnblogs.com/vocaloid01/p/9514302.html
Copyright © 2011-2022 走看看