HDU 2066 一个人的旅行 - from lanshui_Yang
接着有T行,每行有三个整数a,b,time,表示a,b城市之间的车程是time小时;(1=<(a,b)<=1000;a,b 之间可能有多条路)
接着的第T+1行有S个数,表示和草儿家相连的城市;
接着的第T+2行有D个数,表示草儿想去地方。
#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<algorithm>
#include<queue>
#include<cmath>
#include<map>
using namespace std ;
const int MAXN = 1005 ;
const int INF = 0x7fffffff ;
int vis[MAXN] ; // 标记数组,确认城市是否出现过
struct Node
{
int adj ;
int dist ;
Node * next ;
} ;
Node * vert[MAXN] ;
queue <int> q ;
int m , st , dt ;
int dest[MAXN] ;
int ss[MAXN] ; // 记录出发站的城市数目
int dd[MAXN] ; // 记录终点站的城市数目
int dis[MAXN] ;
int inq[MAXN] ;
int sumc ; // 记录出现的不同的城市数目
void spfa(int v0)
{
Node * p ;
int i ;
for(i = 0 ; i <= sumc ; i ++)
{
dis[dest[i]] = INF ;
}
dis[0] = 0 ;
while (!q.empty())
{
q.pop() ;
}
q.push(v0) ;
inq[v0] ++ ;
while (!q.empty())
{
int tmp = q.front() ;
q.pop() ;
inq[tmp] -- ;
p = vert[tmp] ;
while (p != NULL)
{
int td = p -> dist ;
int tadj = p -> adj ;
if(td + dis[tmp] < dis[tadj])
{
dis[tadj] = td + dis[tmp] ;
if(inq[tadj] == 0)
{
inq[tadj] ++ ;
q.push(tadj) ;
}
}
p = p -> next ;
}
}
}
void dele() // 删除邻接表
{
Node * p ;
int i ;
for(i = 0 ; i <= sumc ; i ++)
{
if(i == 0)
p = vert[0] ;
else
p = vert[dest[i]] ;
while (p != NULL)
{
vert[dest[i]] = p -> next ;
delete p ;
p = vert[dest[i]] ;
}
}
}
int main()
{
while (scanf("%d%d%d" , &m , &st , &dt) != EOF)
{
memset(vis , 0 , sizeof(vis)) ;
memset(vert , 0 , sizeof(vert)) ;
memset(dest , 0 , sizeof(dest)) ;
memset(dis , 0 , sizeof(dis)) ;
memset(inq , 0 , sizeof(inq)) ;
int i ;
sumc = 0 ;
Node * p ;
for(i = 0 ; i < m ; i ++)
{
int a , b , w ;
cin >> a >> b >> w ;
if(!vis[a])
{
vis[a] = 1 ;
sumc ++ ;
dest[sumc] = a ;
}
if(!vis[b])
{
vis[b] = 1 ;
sumc ++ ;
dest[sumc] = b ;
}
p = new Node ;
p -> adj = b ;
p -> dist = w ;
p -> next = vert[a] ;
vert[a] = p ; p = new Node ;
p -> adj = a ;
p -> dist = w ;
p -> next = vert[b] ;
vert[b] = p ;
}
for( i = 0 ; i < st ; i ++)
{
scanf("%d" , & ss[i]) ;
if(!vis[ss[i]]) // 这里也不要忘记判断
{
vis[ss[i]] = 1 ;
sumc ++ ;
dest[sumc] = ss[i] ;
}
p = new Node ;
p -> adj = ss[i] ;
p -> dist = 0 ;
p -> next = vert[0] ;
vert[0] = p ; p = new Node ;
p -> adj = 0 ;
p -> dist = 0 ;
p -> next = vert[ss[i]] ;
vert[ss[i]] = p ;
}
for( i = 0 ; i < dt ; i ++)
{
scanf("%d" , & dd[i]) ;
if(!vis[dd[i]]) // 这里也不要忘记判断,终点站的城市可能第一次出现
{
vis[dd[i]] = 1 ;
sumc ++ ;
dest[sumc] = dd[i] ;
}
}
spfa(0) ;
int min = INF ;
for( i = 0 ; i < dt ; i ++)
{
if(min > dis[dd[i]])
{
min = dis[dd[i]] ;
}
}
printf("%d\n" , min) ;
dele() ;
}
return 0 ;
}
HDU 2066 一个人的旅行 - from lanshui_Yang的更多相关文章
- hdu 2066 一个人的旅行
题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=2066 一个人的旅行 Description 虽然草儿是个路痴(就是在杭电待了一年多,居然还会在校园里迷 ...
- hdu 2066 一个人的旅行 Dijkstra
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2066 题意分析:以草儿家为原点,给出城市间相互抵达的时间,给出草儿想去的城市,求最短时间.典型的单源最 ...
- hdu 2066 一个人的旅行(最短路问题)
最短路································· 类似的问题还有好多不会!慢慢学吧!!!!. 进步,哪怕每天一点也行! (恋爱不是小事,确实小事的积累!(听着酷狗音乐台说的,很 ...
- HDU 2066 一个人的旅行(dijkstra水题+判重边)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2066 题目大意:输入数据有多组,每组的第一行是三个整数T,S和D,表示有T条路,和草儿家相邻的城市的有 ...
- hdu 2066 一个人的旅行 解题报告
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2066 题目意思:给出T条路,和草儿家相邻的城市编号,以及草儿想去的地方的编号.问从草儿家到达草儿想去的 ...
- hdu - 2066 一个人的旅行(基础最短路)
http://acm.hdu.edu.cn/showproblem.php?pid=2066 把与草儿相连的城市最短距离置为0,然后进行dijkstra,在t个城市里找出距离最近的一个即可. #inc ...
- HDU 2066 一个人的旅行(单源最短路SPFA)
Description 虽然草儿是个路痴(就是在杭电待了一年多,居然还会在校园里迷路的人,汗~),但是草儿仍然很喜欢旅行,因为在旅途中 会遇见很多人(白马王子,^0^),很多事,还能丰富自己的阅历,还 ...
- hdu 2066 一个人的旅行 最短路径
一个人的旅行 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Sub ...
- HDU 2066 一个人的旅行 (Dijkstra算法)
一个人的旅行 Time Limit : 1000/1000ms (Java/Other) Memory Limit : 32768/32768K (Java/Other) Total Submis ...
随机推荐
- 下载个jquery-easyui-1.3.0使用,把他导入到myeclipse10里,jquery-1.7.2.min.js报错。 错误如下, Syntax error on token "Invalid Regular Expression Options", no accurate correc
1.选中报错的jquery文件“jquery-1.2.6.min.js”.2.右键选择 MyEclipse-->Exclude From Validation .3.再右键选择 MyEclips ...
- Nodejs学习之一 下载安装与部署nodejs
1,下载nodejs 访问nodejs官网 www.nodejs.org/download/ 下载与机器相匹配的版本 2,安装nodejs 下载下来的msi包一直点击下一步即可 3,部署环 ...
- Xcode5 支持 SVN 1.7
Xcode升级了之后出现了各种问题,SVN升级到subversion 1.7后,Xcode自带有svn,版本是1.6,所以svn的1.6和1.7不兼容. 解决的办法,要么是降低系统的svn 版本,要么 ...
- hql查询语句 内存中的情况,fetch迫切查询关键字
Classes.java package cn.itcast.hiberate.sh.domain; import java.io.Serializable; import java.util.Set ...
- IIS6到7,web.config的配置
如果在IIS6中你的web.config中是以下配置: 这是在IIS6中我们习惯的经典模式的配置 < system.web> " " " " &q ...
- JDT入门
1.打开Java类型 要打开一个Java类或Java接口以进行编辑,可以执行以下操作之一: 在编辑器中所显示的源代码里选择所要编辑的Java类或Java接口的名字(或者简单地将插入光标定位到所要编辑的 ...
- gcc 安装
最近在中标麒麟上面工作,结果发现上面gcc都没有,没有办法只好自己装(PS 中标麒麟:怪我咯) 资源:http://download.csdn.net/detail/jiahuat/8715413 按 ...
- android LocalActivityManager说明
类概述 Helper class for managing multiple running embedded activities in the same process. This c ...
- jQuery hover demo
先放效果图: 百度云下载地址:http://pan.baidu.com/s/1dDpn1Sl 代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTM ...
- JavaScript面向对象(01)--函数
在JavaScript中,函数和对象有区别,也有联系, 首先函数是一个对象,但是和对象存在一些区别如下: 1,不论在java还是js中,如果把一个对象赋值给另一个变量,那么,后者会指向前者对象所在的内 ...