HDU-3631 Shortest Path (floyd)
Description
There is a weighted directed multigraph G. And there are following two operations for the weighted directed multigraph:
(1) Mark a vertex in the graph.
(2) Find the shortest-path between two vertices only through marked vertices.
For it was the first time that LMY faced such a problem, she
was very nervous. At this moment, YY decided to help LMY to analyze the
shortest-path problem. With the help of YY, LMY solved the problem at
once, admiring YY very much. Since then, when LMY meets problems, she
always calls YY to analyze the problems for her. Of course, YY is very
glad to help LMY. Finally, it is known to us all, YY and LMY become
programming lovers.
Could you also solve the shortest-path problem?
Input
first line contains three integers N, M and Q, where N is the number of
vertices in the given graph, N≤300; M is the number of arcs, M≤100000;
and Q is the number of operations, Q ≤100000. All vertices are number as
0, 1, 2, … , N - 1, respectively. Initially all vertices are unmarked.
Each of the next M lines describes an arc by three integers (x, y, c):
initial vertex (x), terminal vertex (y), and the weight of the arc (c).
(c > 0) Then each of the next Q lines describes an operation, where
operation “0 x” represents that vertex x is marked, and operation “1 x
y” finds the length of shortest-path between x and y only through marked
vertices. There is a blank line between two consecutive test cases.
End of input is indicated by a line containing N = M = Q = 0.
Output
For operation “0 x”, if vertex x has been marked, output “ERROR! At point x”.
For operation “1 x y”, if vertex x or vertex y isn’t marked,
output “ERROR! At path x to y”; if y isn’t reachable from x through
marked vertices, output “No such path”; otherwise output the length of
the shortest-path. The format is showed as sample output.
There is a blank line between two consecutive test cases.
Sample Input
- 5 10 10
- 1 2 6335
- 0 4 5725
- 3 3 6963
- 4 0 8146
- 1 2 9962
- 1 0 1943
- 2 1 2392
- 4 2 154
- 2 2 7422
- 1 3 9896
- 0 1
- 0 3
- 0 2
- 0 4
- 0 4
- 0 1
- 1 3 3
- 1 1 1
- 0 3
- 0 4
- 0 0 0
- Sample Output
- Case 1:
- ERROR! At point 4
- ERROR! At point 1
- 0
- 0
- ERROR! At point 3
- ERROR! At point 4
- 题目解析:每标记一个点就单独对这个点松弛。要注意有个 "There is a blank line between two consecutive test cases.”
- 代码如下:
- # include<iostream>
- # include<cstdio>
- # include<cstring>
- # include<queue>
- # include<algorithm>
- const int INF=<<;
- using namespace std;
- int mp[][];
- int n,m,q,mark[];
- void floyd(int k)
- {
- for(int i=;i<n;++i)
- for(int j=;j<n;++j)
- mp[i][j]=min(mp[i][j],mp[i][k]+mp[k][j]);
- }
- void work(int s,int t)
- {
- if(mark[s]==||mark[t]==)
- printf("ERROR! At path %d to %d\n",s,t);
- else{
- if(mp[s][t]!=INF)
- printf("%d\n",mp[s][t]);
- else
- printf("No such path\n");
- }
- }
- int main()
- {
- //freopen("Qcin.txt","r",stdin);
- int a,b,c,i,j,cas=;
- while(scanf("%d%d%d",&n,&m,&q)==)
- {
- if(n==&&m==&&q==)
- break;
- if(cas)
- printf("\n");
- for(i=;i<n;++i)
- for(j=;j<n;++j)
- mp[i][j]=(i==j)?:INF;
- memset(mark,,sizeof(mark));
- while(m--)
- {
- scanf("%d%d%d",&a,&b,&c);
- mp[a][b]=min(mp[a][b],c);
- }
- int comd;
- printf("Case %d:\n",++cas);
- while(q--)
- {
- scanf("%d",&comd);
- if(comd==){
- scanf("%d",&a);
- if(mark[a]){
- printf("ERROR! At point %d\n",a);
- }else{
- mark[a]=;
- floyd(a);
- }
- }
- else if(comd==){
- scanf("%d%d",&a,&b);
- work(a,b);
- }
- }
- }
- return ;
- }
HDU-3631 Shortest Path (floyd)的更多相关文章
- hdu 3631 Shortest Path(Floyd)
题目链接:pid=3631" style="font-size:18px">http://acm.hdu.edu.cn/showproblem.php?pid=36 ...
- HDU 5636 Shortest Path(Floyd)
题目链接 HDU5636 n个点,其中编号相邻的两个点之间都有一条长度为1的边,然后除此之外还有3条长度为1的边. m个询问,每次询问求两个点之前的最短路. 我们把这三条边的6个点两两算最短路, 然 ...
- HDU - 3631 Shortest Path(Floyd最短路)
Shortest Path Time Limit: 1000MS Memory Limit: 32768KB 64bit IO Format: %I64d & %I64u SubmitStat ...
- Shortest Path(hdu5636)
Shortest Path Accepts: 40 Submissions: 610 Time Limit: 4000/2000 MS (Java/Others) Memory Limit: ...
- HDU - 1973 - Prime Path (BFS)
Prime Path Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total ...
- hdu 3631 Shortest Path
floyd算法好像很奇妙的样子.可以做到每次加入一个点再以这个点为中间点去更新最短路,效率是n*n. #include<cstdio> #include<cstring> #i ...
- HDU ACM 1869 六度分离(Floyd)
六度分离 Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submis ...
- Leetcode 943. Find the Shortest Superstring(DP)
题目来源:https://leetcode.com/problems/find-the-shortest-superstring/description/ 标记难度:Hard 提交次数:3/4 代码效 ...
- HDU 5938 Four Operations(四则运算)
p.MsoNormal { margin: 0pt; margin-bottom: .0001pt; text-align: justify; font-family: Calibri; font-s ...
随机推荐
- python学习读取配置文件
配置文件作为一种可读性很好的格式,非常适用于存储程序中的配置数据. 在每个配置文件中,配置数据会被分组(比如“config”和 “cmd”). 每个分组在其中指定对应的各个变量值.如下: # 定义co ...
- Advapi32.dll--介绍
https://blog.csdn.net/zhoujielun123456/article/details/50338147 使用方法详见:OpsTotalService
- python中hasattr, getattr,setattr及delattr四个方法
通过一个实例来说明,这四个函数的用法: 首先一个如下的一个简单的类: class Animal(object): def __init__(self,name, zone): self.name = ...
- LOJ10067 构造完全图
LOJ10067 构造完全图 最小生成树 每次找到最小的边,将边两端的块合并 (我之前想的是什么鬼) #include<cstdio> #include<algorithm> ...
- Java 执行jar文件出现版本错误信息
Java 执行jar文件出现版本错误信息 一.问题 执行jar文件出现如下错误信息: 二.解决方案 是因为在创建工程的时候选择的jdk编译版本,和执行jar环境的jdk版本不一致: 更改工程的jdk版 ...
- djando 项目用django自己服务器在局域网中被访问设置
这是一个相当操蛋的东西,害老子搞了那么久,其实嘞,也用不着那么恨,都是自己做的孽!! -----------------人工分割线----------------------------------- ...
- CRT中的时间(time_t和tm)(转载)
转载:http://blog.csdn.net/bokee/article/details/5330682 首先介绍基本的时间概念. 时间一般分为两种,一种是本地时间(Local Time),一种是协 ...
- 使用ShellExecute打开默认程序(邮件客户端)
转载:http://www.cnblogs.com/xubin0523/archive/2012/11/01/2749729.html ShellExecute ShellExecute的功能是运行一 ...
- 关于activity生命周期,启动模式和tag
Acticity启动模式 1.standard:Activity的默认加载方法,该方法会通过跳转到一个新的activity,同时将该实例压入到栈中(不管该activity是否已经存在在Task栈中,都 ...
- 在Android studio中到入Eclipse
由于无法在AS中直接导入Eclipse的原始包,所以需要先把Eclipse的包导出成Gradle包,这个Gradle包可以别两个环境识别. 1.在Eclipse中导出Gradle包.选择需要从Ecli ...