一个人的旅行 HDU杭电2066【dijkstra算法 || SPFA】

http://acm.hdu.edu.cn/showproblem.php?

pid=2066

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

//Dijkstra

#include<stdio.h>
#include<string.h>
#define INF 0x3f3f3f3f
int map[1010][1010];
int dis[1010];
bool used[1010];
int n;
int i,j;
void dijkstra()
{
	int i,j;
	memset(used,0,sizeof(used));
	for(i=0;i<=1000;++i)
		dis[i]=INF;
	int pos;
	for(i=0;i<=1000;++i)//第一次给dis赋值
	{
		dis[i]=map[0][i];
	}
	dis[0]=0;
	used[0]=1;
	for(i=0;i<1000;++i)//最多执行n次
	{
		int min=INF;
		for(j=0;j<=1000;++j)
		{
			if(!used[j]&&dis[j]<min)
			{
				min=dis[j];
				pos=j;
			}
		}
		used[pos]=1;
		dis[pos]=min;
		for(j=0;j<=1000;++j)//把dis数组更新。也叫松弛
		{
			if(!used[j]&&dis[j]>map[pos][j]+dis[pos])
			{
				dis[j]=map[pos][j]+dis[pos];
			}
		}
	}
}
int main()
{
	int m,T;
	int u,v,w;
	int temp;
	int a[1010],b[1010];
	while(~scanf("%d%d%d",&n,&m,&T))
	{
		for(i=0;i<=1000;++i)
      		for(j=0;j<=i;++j)
        		map[i][j]=map[j][i]=INF;
		for(i=1;i<=n;++i)
		{
			scanf("%d%d%d",&u,&v,&w);
			if(map[u][v]>w)
				map[u][v]=map[v][u]=w;
		}
		for(i=1;i<=m;++i)
		{
			scanf("%d",&temp);
			map[0][temp]=0;
		}
		dijkstra();
		int min=INF;
		for(i=1;i<=T;++i)
		{
			scanf("%d",&temp);
			if(dis[temp]<min) min=dis[temp];
		}
		printf("%d\n",min);
	}
	return 0;
}

//SPFS

#include <cstdio>
#include <cstring>
#include <queue>
#define MAXN 1100
#define MAXM 10100
#define INF 0x3f3f3f3f
using namespace std;
struct Edge
{
	int u, v, w;
	int next;//下一个结构体变量的下标
}edge[MAXM];
int head[MAXN];//下标为起点u,值为相应结构体下标
int vis[MAXN];//推断是否增加队列了
int num;
int low[MAXN];//存最短路径
void Add_Edge(int u, int v, int w)//加边
{
	Edge E={u, v, w, head[u]};//初始化结构体
	edge[num]=E;//直接赋值
	head[u]=num++;
}
void SPFA(int s)
{
	int i, j;
	queue<int> Q;
	memset(low, INF, sizeof(low));
	memset(vis, 0, sizeof(vis));
	vis[s] = 1;
	low[s]=0;
	Q.push(s);
	while(!Q.empty())
	{
		int u=Q.front();
		Q.pop();
		vis[u]=0;//出队列了,不在队列就变成0
		for(j = head[u]; j != -1; j = edge[j].next)
		{
			int v = edge[j].v;
			if(low[v] > low[u] + edge[j].w)
			{
				low[v] = low[u] + edge[j].w;
				if(!vis[v])
			 	{
			 		vis[v]=1;
			 		Q.push(v);
			 	}
			}
		}
	}
}
int main()
{
	int u, v, w;
	int S,E,M,N,s,e;
	while(~scanf("%d%d%d", &N, &S,&E))
	{
		memset(head, -1, sizeof(head));
		num=0;
		for(int i=1; i <= N; ++i)
		{
			scanf("%d%d%d", &u, &v, &w);
			Add_Edge(u, v, w);
			Add_Edge(v, u, w);//无向边
		}
		while(S--)
		{
			scanf("%d",&s);
			Add_Edge(0,s,0);//建万能源点
		}
		SPFA(0);
		int min=INF;
		while(E--)
		{
			scanf("%d",&e);
			if(min>low[e]) min=low[e];
		}
		printf("%d\n",min);
	}
	return 0;
}
时间: 2024-10-12 12:27:24

一个人的旅行 HDU杭电2066【dijkstra算法 || SPFA】的相关文章

一个人的旅行 HDU杭电2066【dijkstra算法】

http://acm.hdu.edu.cn/showproblem.php?pid=2066 Problem Description 虽然草儿是个路痴(就是在杭电待了一年多,居然还会在校园里迷路的人,汗~),但是草儿仍然很喜欢旅行,因为在旅途中 会遇见很多人(白马王子,^0^),很多事,还能丰富自己的阅历,还可以看美丽的风景--草儿想去很多地方,她想要去东京铁塔看夜景,去威尼斯看电影,去阳明山上看海芋,去纽约纯粹看雪景,去巴黎喝咖啡写信,去北京探望孟姜女--眼看寒假就快到了,这么一大段时间,可不

『ACM C++』HDU杭电OJ | 1415 - Jugs (灌水定理引申)

今天总算开学了,当了班长就是麻烦,明明自己没买书却要带着一波人去领书,那能怎么办呢,只能说我善人心肠哈哈哈,不过我脑子里突然浮起一个念头,大二还要不要继续当这个班委呢,既然已经体验过就可以适当放下了吧,用心在自己的研究上.晚上级会开完也就八点多了,开始打打题,今天在HDU杭电的ACM集训题看到一个奇葩的题,前来献上. 今日推荐: <全球风暴> 一部宇宙航空和地球气候片的良心佳作,后期特效建模都是特别杠杠的大片,不会让你失望的哟,我已经三刷了哈哈哈.这部片在爱奇艺有上线,有兴趣的朋友可以看看鸭.

hdu 2680 最短路径(dijkstra算法+多源最短路径单源化求最小值)

Choose the best route Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 7062    Accepted Submission(s): 2301 Problem Description One day , Kiki wants to visit one of her friends. As she is liable

杭电 2066 一个人的旅行

Description 虽然草儿是个路痴(就是在杭电待了一年多,居然还会在校园里迷路的人,汗~),但是草儿仍然很喜欢旅行,因为在旅途中 会遇见很多人(白马王子,^0^),很多事,还能丰富自己的阅历,还可以看美丽的风景……草儿想去很多地方,她想要去东京铁塔看夜景,去威尼斯看电影,去阳明山上看海芋,去纽约纯粹看雪景,去巴黎喝咖啡写信,去北京探望孟姜女……眼看寒假就快到了,这么一大段时间,可不能浪费啊,一定要给自己好好的放个假,可是也不能荒废了训练啊,所以草儿决定在要在最短的时间去一个自己想去的地方!

一个人的旅行(杭电oj2066)(Dijkstra算法)

一个人的旅行 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 20267    Accepted Submission(s): 7081 Problem Description 虽然草儿是个路痴(就是在杭电待了一年多,居然还会在校园里迷路的人,汗~),但是草儿仍然很喜欢旅行,因为在旅途中 会遇见很多人(白马王子,^0^),很多事,还能丰

畅通project续HDU杭电1874【dijkstra算法 || SPFA】

http://acm.hdu.edu.cn/showproblem.php?pid=1874 Problem Description 某省自从实行了非常多年的畅通project计划后.最终修建了非常多路.只是路多了也不好,每次要从一个城镇到还有一个城镇时,都有很多种道路方案能够选择,而某些方案要比还有一些方案行走的距离要短非常多.这让行人非常困扰. 如今,已知起点和终点,请你计算出要从起点到终点.最短须要行走多少距离. Input 本题目包括多组数据.请处理到文件结束. 每组数据第一行包括两个正

ACM: HDU 2544 最短路-Dijkstra算法

HDU 2544最短路 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Description 在每年的校赛里,所有进入决赛的同学都会获得一件很漂亮的t-shirt.但是每当我们的工作人员把上百件的衣服从商店运回到赛场的时候,却是非常累的!所以现在他们想要寻找最短的从商店到赛场的路线,你可以帮助他们吗? Input 输入包括多组数据.每组数据第一行是两个整数N.M(N<=100,M<

ACM: HDU 3790 最短路径问题-Dijkstra算法

HDU 3790 最短路径问题 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Description 给你n个点,m条无向边,每条边都有长度d和花费p,给你起点s终点t,要求输出起点到终点的最短距离及其花费,如果最短距离有多条路线,则输出花费最少的. Input 输入n,m,点的编号是1~n,然后是m行,每行4个数 a,b,d,p,表示a和b之间有一条边,且其长度为d,花费为p.最后一行是

Choose the best route HDU杭电2680【dijkstra算法】

http://acm.hdu.edu.cn/showproblem.php?pid=2680 Problem Description One day , Kiki wants to visit one of her friends. As she is liable to carsickness , she wants to arrive at her friend's home as soon as possible . Now give you a map of the city's tra