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 ...
随机推荐
- Hadoop 学习总结之一:HDFS简介
一.HDFS的基本概念 1.1.数据块(block) HDFS(Hadoop Distributed File System)默认的最基本的存储单位是64M的数据块. 和普通文件系统相同的是,HDFS ...
- Func<T, TResult> 委托的由来和调用和好处(为了高大上,为了白富美)
Func<T, TResult>是系统的内置委托的中最常用的一个.特点就是必须有一个返回值.(func委托有多个重载,所有重载的最后一个参数就是返回值的类型,前面的是参数类型).注:没有返 ...
- eclipse 工程加入ant以支持自动打war包
先在工程的根目录下建一个一builder.xml内容如下 <project basedir="." default="war" name="hb ...
- jQuery插件开发的模式和结构
jQuery插件开发 一般来说,jQuery插件的开发分为两种:一种是挂在jQuery命名空间下的全局函数,也可称为静态方法:另一种是jQuery对象级别的方法,即挂在jQuery原型下的方法,这样通 ...
- 关于COUNT STOPKEY的工作机制(转载)
SQL> select rownum rn ,a.* from cnmir.ew_auctions a where rownum<50000; Execution Plan-------- ...
- Android 者开发如何选择测试机列表
Android 系统已经分化成多种不同的定制版本,制造厂商的不同手机使用的硬件千差万别.差异化带来良好的用户体验的同时,也给开发者带来的适配的问题.于是每个开发团队都需要面临选择测试机列表的问题.我基 ...
- 安装linux操作系统--浪潮服务器
一直都是在虚拟机上进行安装linux操作系统,在服务器上安装的很少,也没有碰到过没找到驱动的情况,例如什么raid卡驱动,网卡驱动等异常情况的发生. 这次安装了两台服务器,浪潮的提供的服务器,硬盘是两 ...
- 关于python中的__new__方法
在上篇中,简单的比较了下new方法和init方法,然后结合网上的东西看了一点,发现..看书有的时候说的并不全面. __new__方法是一个类方法,主要作用是来指导如何生成类的实例, 主要用于,当需要生 ...
- 前端架构:Angular与requirejs集成实践
这几天angular与requirejs.browserify的集成弄的博主头好晕,今天终于成功集成了requirejs,现写些心得体会在这里. 核心思想:angular加载时有一定的顺序,必须依次加 ...
- Code-first示例
首先创建一个空数据库 在vs2013中添加数据库类,按提示操作一直下一步 添加完以后,数据库类的代码 namespace mvctest.Models { using System; using ...