Heavy Transportation
Time Limit: 3000MS   Memory Limit: 30000K
Total Submissions: 26968   Accepted: 7232

Description

Background
Hugo Heavy is happy. After the breakdown of the Cargolifter project
he can now expand business. But he needs a clever man who tells him
whether there really is a way from the place his customer has build his
giant steel crane to the place where it is needed on which all streets
can carry the weight.

Fortunately he already has a plan of the city with all streets and
bridges and all the allowed weights.Unfortunately he has no idea how to
find the the maximum weight capacity in order to tell his customer how
heavy the crane may become. But you surely know.

Problem

You are given the plan of the city, described by the streets (with
weight limits) between the crossings, which are numbered from 1 to n.
Your task is to find the maximum weight that can be transported from
crossing 1 (Hugo's place) to crossing n (the customer's place). You may
assume that there is at least one path. All streets can be travelled in
both directions.

Input

The
first line contains the number of scenarios (city plans). For each city
the number n of street crossings (1 <= n <= 1000) and number m of
streets are given on the first line. The following m lines contain
triples of integers specifying start and end crossing of the street and
the maximum allowed weight, which is positive and not larger than
1000000. There will be at most one street between each pair of
crossings.

Output

The
output for every scenario begins with a line containing "Scenario #i:",
where i is the number of the scenario starting at 1. Then print a
single line containing the maximum allowed weight that Hugo can
transport to the customer. Terminate the output for the scenario with a
blank line.

Sample Input

1
3 3
1 2 3
1 3 4
2 3 5

Sample Output

Scenario #1:
4
题目大意,有n个城m条边,每个边有个最大的通过量,求1城市到n城市的一条最大通路容量是多少
迪杰斯特拉算法的变形,松弛条件改为道路容量为道路上容量最小的边,然后在选容量最大的路
ac代码如下:
 #include<iostream>
#include<algorithm>
#include<cstring>
#include<memory.h>
using namespace std;
long map[][];
long dp[],n;
bool v[];
void dij(int ii){
for(int i=;i<=n;i++){
dp[i]=map[ii][i];
}
dp[ii]=;v[ii]=;
int T=n;
while(T--){
int k=-,s;
for(int i=;i<=n;i++){//找下一条边
if(dp[i]>k&&!v[i]){
k=dp[i];
s=i;
}
}
v[s]=;
if(s==n)return;
for(int i=;i<=n;i++){//利用下一条边进行松弛
if(!v[i]&&dp[i]<min(dp[s],map[s][i])){
dp[i]=min(dp[s],map[s][i]);
}
}
}
}
int main(){
long T,m,s,e,c,ca=;
cin>>T;
while(T--){
cin>>n>>m;
memset(v,,sizeof(v));
memset(dp,,sizeof(dp));
memset(map,,sizeof(map));
for(int i=;i<=m;i++){
cin>>s>>e>>c;
map[s][e]=map[e][s]=max(map[s][e],c);
}
dij();
cout<<"Scenario #"<<ca++<<":"<<endl;
cout<<dp[n]<<endl<<endl;
}
return ;
}

提交结果:

poj 1797 Heavy Transportation(最短路径Dijkdtra)的更多相关文章

  1. POJ 1797 Heavy Transportation / SCU 1819 Heavy Transportation (图论,最短路径)

    POJ 1797 Heavy Transportation / SCU 1819 Heavy Transportation (图论,最短路径) Description Background Hugo ...

  2. poj 1797 Heavy Transportation(最大生成树)

    poj 1797 Heavy Transportation Description Background Hugo Heavy is happy. After the breakdown of the ...

  3. POJ.1797 Heavy Transportation (Dijkstra变形)

    POJ.1797 Heavy Transportation (Dijkstra变形) 题意分析 给出n个点,m条边的城市网络,其中 x y d 代表由x到y(或由y到x)的公路所能承受的最大重量为d, ...

  4. POJ 1797 Heavy Transportation

    题目链接:http://poj.org/problem?id=1797 Heavy Transportation Time Limit: 3000MS   Memory Limit: 30000K T ...

  5. POJ 1797 Heavy Transportation SPFA变形

    原题链接:http://poj.org/problem?id=1797 Heavy Transportation Time Limit: 3000MS   Memory Limit: 30000K T ...

  6. POJ 1797 Heavy Transportation (Dijkstra变形)

    F - Heavy Transportation Time Limit:3000MS     Memory Limit:30000KB     64bit IO Format:%I64d & ...

  7. POJ 1797 ——Heavy Transportation——————【最短路、Dijkstra、最短边最大化】

    Heavy Transportation Time Limit:3000MS     Memory Limit:30000KB     64bit IO Format:%I64d & %I64 ...

  8. POJ 1797 Heavy Transportation (最大生成树)

    题目链接:POJ 1797 Description Background Hugo Heavy is happy. After the breakdown of the Cargolifter pro ...

  9. POJ 1797 Heavy Transportation (Dijkstra)

    题目链接:POJ 1797 Description Background Hugo Heavy is happy. After the breakdown of the Cargolifter pro ...

随机推荐

  1. ganymedssh2 java执行linux命令

    需要下载ganymed-ssh2-262.jar package ganymed; import java.io.BufferedReader; import java.io.IOException; ...

  2. 如何从NFS文件系统启动

    笔记,备忘! 步骤: 1.设置好NFS服务器 2.修改uboot启动参数bootarg setenv bootargs console=ttySAC0 root=/dev/nfs nfsroot=19 ...

  3. 20160808_卸载OpenJDK

    1.查看信息 [root@localhost ~]# rpm -qa | grep jdkjava-1.6.0-openjdk-devel-1.6.0.0-1.50.1.11.5.el6_3.x86_ ...

  4. cpu缓存与多线程

    一.cpu缓存结构 CPU速度远高于内存(即如果只考虑CPU和内存因素,程序的性能常常受到内存访问速度的限制,内存访问和运行),为了协调CPU和内存在速度上的差异,在CPU中增加了高速缓存.和计算机存 ...

  5. Python设计模式之单例模式

    1.由于语言的特性不同,设计模式的实现方式和实现难度也会不同 2.有的模式已经在语言内置了,比如迭代器模式. 3.单例模式可以直接用模块级变量来实现 4.普通工厂模式可以直接通过传入"类名& ...

  6. $.extend abc

    console.log(jQuery.extend(this,{'a':'b'},{'c':'d'}));console.log(this.a)var tt = jQuery.extend({},{' ...

  7. Fragment 笔记

    1.getActivity()  为null问题 在Fragment基类里设置一个Activity mActivity的全局变量,在onAttach(Activity activity)里赋值,使用m ...

  8. android 开发 常用工具类

    转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/38965311,本文出自[张鸿洋的博客] 打开大家手上的项目,基本都会有一大批的辅 ...

  9. const修饰指针

    关于const修饰指针的情况,一般分为如下4种情况: ; const int *a =&b; //情况1 int const *a =&b; //情况2 int* const a =& ...

  10. 【转】 FPGA设计的四种常用思想与技巧

    本文讨论的四种常用FPGA/CPLD设计思想与技巧:乒乓操作.串并转换.流水线操作.数据接口同步化,都是FPGA/CPLD逻辑设计的内在规律的体现,合理地采用这些设计思想能在FPGA/CPLD设计工作 ...