hdu2066一个人的旅行(floyd优化)
一个人的旅行
Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 52212    Accepted Submission(s): 17369
接着有T行,每行有三个整数a,b,time,表示a,b城市之间的车程是time小时;(1=<(a,b)<=1000;a,b 之间可能有多条路)
接着的第T+1行有S个数,表示和草儿家相连的城市;
接着的第T+2行有D个数,表示草儿想去地方。
题意:给出每两个城市之间公交车的车程。和相邻的城市,和目的城市。求出从相邻城市出发到目的城市的最短车程。
题解:因为这题的城市数量最多到1000,用floyd算法比较极限,所以要优化!!不然会T的很快乐。从每个相邻城市到目的城市的车程最小值可以放到floyd算法里面求,不用拿到外面,min函数也尽量不要用,在floyd算法里面,i到k如果没有车,就跳过直接到下一个,这样可以少一个for循环的时间。
#include<bits/stdc++.h>
using namespace std;
int t,s,d;
int a[][];
int b[],c[];
const int inf=0x3f3f3f3f;
int n=;
int floyd() {
int minn=inf;
for(int k=; k<=n; k++) {
for(int i=; i<=n; i++) {
if(a[i][k]!=inf) {//优化 判断一下两个城市之间没有车就跳过,继续下一个,这里很关键
for(int j=; j<=n; j++) {
//a[i][j]=min(a[i][j],a[i][k]+a[k][j]);
a[i][j]=a[i][j]<a[i][k]+a[k][j]?a[i][j]:a[i][k]+a[k][j];
if(b[i]&&c[j]&&minn>a[i][j])
minn=a[i][j];
}
} }
}
return minn;
}
void init() {
for(int i=; i<; i++) {
for(int j=; j<; j++) {
a[i][j]=inf;
}
a[i][i]=;
}
}
int main() {
while(~scanf("%d %d %d",&t,&s,&d)) {
init();
memset(b,,sizeof(b));
memset(c,,sizeof(c));
for(int i=; i<=t; i++) {
int x,y,z;
scanf("%d %d %d",&x,&y,&z);
if(z<a[x][y])a[x][y]=a[y][x]=z;
if(n<x)n=x;
if(n<y)n=y;
}
for(int i=; i<s; i++) {
int temp;
scanf("%d",&temp);
b[temp]=;
}
for(int i=; i<d; i++) {
int temp;
scanf("%d",&temp);
c[temp]=;
}
printf("%d\n",floyd());
n=;
}
return ;
}
hdu2066一个人的旅行(floyd优化)的更多相关文章
- 一个人的旅行(floyd+dijskra+SPFA+Bellman)
		
一个人的旅行 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Subm ...
 - hdu2066 一个人的旅行 最短路
		
单源最短路裸题 #include<stdio.h> #include<string.h> #define min(a,b) (a)<(b)?a:b #define INF ...
 - HDU2066一个人的旅行---(多起点多终点最短路径)
		
http://acm.hdu.edu.cn/showproblem.php?pid=2066 一个人的旅行 Time Limit: 1000/1000 MS (Java/Others) Memo ...
 - 一个人的旅行-Floyd
		
一个人的旅行 Time Limit : 1000/1000ms (Java/Other) Memory Limit : 32768/32768K (Java/Other) Total Submis ...
 - HDU2066一个人的旅行(dijkstra)
		
一开始拿到这个题感觉floyd可能会超,还是写了写,果然1WA+1TLE,之后觉得用dijkstra试试看看S和D会不会比较小,还是1WA+1TLE,最后还是借鉴了别人的做法. 把他的家作为起点,与他 ...
 - hdu2066一个人的旅行(dijkstra)
		
Problem Description 虽然草儿是个路痴(就是在杭电待了一年多,居然还会在校园里迷路的人,汗~),但是草儿仍然很喜欢旅行,因为在旅途中 会遇见很多人(白马王子,^0^),很多事,还能丰 ...
 - HDU2066一个人的旅行/最短路问题
		
一个人的旅行 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Subm ...
 - HDU2066 一个人的旅行 最短路基础
		
新手熟悉一下迪杰斯特拉... 一个人的旅行 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Ot ...
 - hdu2066一个人的旅行(disjkstra)
		
一个人的旅行 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Subm ...
 
随机推荐
- if not
			
if not x 在python中的意思是如果x为空 a = [] if not a: print 1 此代码会打印出1 a = [1,2,3] if not a: print 1 此代码不会打印出1 ...
 - 利用Apache Isis快速原型化-宠物诊所的宠物管理
			
前言 Apache Isis是DDD方法的一个实现框架. 需求分析 宠物诊所需要记录宠物的资料,包括类型.名字.及其主人. 多个宠物可能同属于一个主人. 宠物可能更换主人. 宠物主人记录姓名,我们可以 ...
 - Hello, GitHub!
			
GitHub作为版本控制的软件,我决定重新系统学习这个东西,毕竟以前都是fork.clone... 1. 理解Git思维 首先呢,我一开始就被GitHub和Git两个东西搞昏了,所以有必要理解二者的关 ...
 - C#发送邮件类库
			
public class Email { #region 发送邮件 /// <summary> /// 发送邮件 /// </summary> /// <param na ...
 - day 03 --Haproxy 增加, 删除,查询
			
key 知识点:函数的定义, 函数的递归调用, flag 标志位的使用,eval() 函数 #!C:\Program Files\Python35\bin # -*- conding:utf-8 -* ...
 - django模板中如何导入js、css等外部文件
			
本教程只适合Django1.4版本.(1.8版本之后不需要这么麻烦,详见 http://www.cnblogs.com/ryan255/p/5465608.html) html模板里面使用了css,但 ...
 - iOS:文件操作相关(18-03-23更)
			
0.iOS文件系统 1.工程内文件 2.文件夹管理 3.文件操作 4.NSCache 附录: 1.沙盒文件夹.文件大小 2.清除沙盒 Library / Cache 下所有数据 3.测试plist 0 ...
 - iOS | 解决中文乱码
			
在iOS开发中,多多少少的朋友在开发的过程中,测试数据的时候可能会碰到后台打印的时候不能正确的打印出正常的汉字,打印出一些影响判断的字符,经常需要查看数组中得元素是否是自己想要的,但是苹果并没有对直接 ...
 - iOS之动态计算文字的高度
			
+ (CGSize)boundingALLRectWithSize:(NSString *)txt Font:(UIFont *)font Size:(CGSize)size { NSMutableA ...
 - 聊聊c#与Python以及IronPython
			
简单说说这个意义.做了很久的c#,突然发现Python火了.就看看,估计这篇博文有点长,有点长,尽量包括主要的东西,还有点杂,浏览吧,选择自己喜欢的看看. 先看比较.网上一堆各种比较.但是主要比较语法 ...