hpu 1413
来源:互联网 发布:色内内电影网新域名 编辑:程序博客网 时间:2024/05/16 11:47
1413: StarFarming [最短路]
时间限制: 1 Sec 内存限制: 128 MB提交: 431 解决: 68 统计
题目描述
星农(StarFarming)公司计划要给员工发路费津贴,发放的规则是这样的:1
到n-1
代表各个员工家的序号,n
代表公司。路费津贴只发给上班的最短路与回家的最短路的总路程最长的人。该市的路建造的有些奇怪,修路只修单行道,即只允许往某一个方向通行。
现在给你城市的有向图的地图,TLG请你帮忙计算谁能得到津贴,以及他上班和回家的总路程是多少。
输入
有多组测试数据。
每组第一行输入两个整数N
,M
。表示点的个数,与单行道的数量(可能有重复)
接下来m
行,每行输入三个整数x
,y
,z
。表示从x
到y
城市有一条单行道,距离为z
。
题目保证至少一人存在来回的路径。不存在的不发津贴(班都没法好好上还想要钱?!)
输出
对于每组数据,输出两个整数,分别表示获得津贴的人的序号以及总路程。(如果有多个人路程相同,取序号最小的)
样例输入
4 71 2 22 3 21 3 44 1 24 2 23 4 14 3 5
样例输出
1 7
提示
对于样例,
1
来回需要的最短路程是7
:1->2->3->4->1
2
来回需要的最短路程是5
:2->3->4->2
3
来回需要的最短路程是5
:3->4->2->3
所以输出1 7
使用 弗洛伊德超时 先补 弗洛伊德代码 等等再补 迪杰斯特拉代码
#include<bits/stdc++.h>using namespace std;int dp[10001][10001];int main(){ int n,m,x,y,z; cin>>n>>m; int j,k,l,i; for(j=1;j<=n;j++){ for(k=1;k<=n;k++){ dp[j][k]=99999999; } } for(j=0;j<m;j++){ cin>>x>>y>>z; dp[x][y]=z; } for(j=1;j<=n;j++){ for(k=1;k<=n;k++){ for(i=1;i<=n;i++){ dp[k][i]=min(dp[k][i],dp[k][j]+dp[j][i]); // cout<<k<<" "<<i<<" "<<dp[k][i]<<endl; } } } int mx=0; for(j=1;j<=n;j++){ if(dp[j][j]>mx) mx=dp[j][j]; } cout<<mx<<endl; return 0;}
阅读全文
1 0
- hpu 1413
- HPU
- [HPU
- [HPU
- HPU 1413: StarFarming [最短路]
- HPU 1413 StarFarming (最短路)
- hpu 1413: StarFarming(图论,有向图反向存边)
- hpu--1703
- hpu--1715
- hpu--1717
- hpu 1032
- hpu E
- HPU D
- HPU C
- HPU A
- HPU G
- HPU 周练一
- HPU 1192
- 第一行代码 第7章 内容提供器 --基本用法
- linux 安装vsftpd
- java内存区域详解
- mysql数据库“光标”移动机制实现的分页查询
- QQ的第三方登录
- hpu 1413
- 无向图的连通分量
- 手机对红外探头发送数据和接受
- 抽象类 | 接口 | 包 | 访问控制
- 树
- 未来两周工作安排
- JAVA中的反射机制
- 转--FPGA全局时钟系统的设计
- 前端框架沉思录(上)