Cycling
Cycling |
| Time Limit: 5000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) |
| Total Submission(s): 105 Accepted Submission(s): 49 |
|
Problem Description
You want to cycle to a programming contest. The shortest route to the contest might be over the tops of some mountains and through some valleys. From past experience you know that you perform badly in programming contests after experiencing large differences in altitude. Therefore you decide to take the route that minimizes the altitude difference, where the altitude difference of a route is the difference between the maximum and the minimum height on the route. Your job is to write a program that finds this route.
You are given: the number of crossings and their altitudes, and the roads by which these crossings are connected.
In this case the shortest path from 1 to 7 would be through 2, 3 and 4, but the altitude difference of that path is 8. So, you prefer to go through 5, 6 and 4 for an altitude difference of 2. (Note that going from 6 directly to 7 directly would have the same difference in altitude, but the path would be longer!) |
|
Input
On the first line an integer t (1 <= t <= 100): the number of test cases. Then for each test case:
One line with two integers n (1 <= n <= 100) and m (0 <= m <= 5000): the number of crossings and the number of roads. The crossings are numbered 1..n. n lines with one integer hi (0 <= hi <= 1 000 000 000): the altitude of the i-th crossing. m lines with three integers aj , bj (1 <= aj , bj <= n) and cj (1 <= cj <= 1 000 000): this indicates that there is a two-way road between crossings aj and bj of length cj . You may assume that the altitude on a road between two crossings changes linearly. |
|
Output
For each testcase, output one line with two integers separated by a single space:
the minimum altitude difference, and the length of shortest path with this altitude difference. |
|
Sample Input
1 |
|
Sample Output
2 11 |
|
Source
bapc2007_pre
|
|
Recommend
lcy
|
/*
题意:小明上学,从1到n,每个点都有高度,让你找出来一条高度差最小,这个条件下的最短路 初步思路:将所有的高度差计算出来,然后排序,从小到大找到第一个,能找到最短路的输出 #问题:很奇怪计算高度差的时候还要考虑和自身的高度差
*/
#include<bits/stdc++.h>
using namespace std;
struct Point{
int low,high;
Point(){}
Point(int a,int b){
low=a;
high=b;
}
bool operator < (const Point & b) const{
return (high-low)<(b.high-b.low);
}
};
int t;
int n,m;
int h[];
Point difference_h[*];
int u,v,val;
int tol=;
/*****************************************************spaf模板*****************************************************/
const int MAXN = ;
const int INF = 0x3f3f3f3f;
struct Edge {
int v;
int cost;
Edge(int _v = , int _cost = ) :
v(_v), cost(_cost) {
}
};
vector<Edge> E[MAXN];
void addedge(int u, int v, int w) {
E[u].push_back(Edge(v, w));
E[v].push_back(Edge(u, w));
}
bool vis[MAXN]; //在队列标志
int cnt[MAXN]; //每个点的入队列次数
int dist[MAXN];
bool SPFA(int start, int n,int low,int high) {
memset(vis, false, sizeof(vis));
for (int i = ; i <= n; i++)
dist[i] = INF;
vis[start] = true;
dist[start] = ;
queue<int> que;
while (!que.empty())
que.pop();
que.push(start);//将第一个点放进队列
memset(cnt, , sizeof(cnt));
cnt[start] = ;//标记一下这个点第一次进入队列中
while (!que.empty()) {
int u = que.front();
que.pop();
if(h[u]<low||h[u]>high)//控制高度差
continue;
vis[u] = false;
for (int i = ; i < E[u].size(); i++) {//遍历他所有能链接到的边
int v = E[u][i].v;
if (h[v]>=low&&h[v]<=high&&dist[v] > dist[u] + E[u][i].cost) {//进行缩点
dist[v] = dist[u] + E[u][i].cost;
if (!vis[v]) {//这个点没有访问过
vis[v] = true;
que.push(v);
if (++cnt[v] > n)
return false; //cnt[i]为入队列次数,用来判定是否存在负环回路
}
}
}
}
return true;
}
/*****************************************************spaf模板*****************************************************/
void init(){
for(int i=;i<=n;i++){
E[i].clear();
}
tol=;
}
int main(){
// freopen("in.txt","r",stdin);
scanf("%d",&t);
while(t--){
scanf("%d%d",&n,&m);
init();
for(int i=;i<=n;i++){
scanf("%d",&h[i]);
}
for(int i=;i<m;i++){
scanf("%d%d%d",&u,&v,&val);
//建图
addedge(u,v,val);
}
// cout<<"ok"<<endl;
for(int i=;i<=n;i++){
for(int j=i;j<=n;j++){
difference_h[tol].low=min(h[i],h[j]);
difference_h[tol++].high=max(h[i],h[j]);
}
}
// cout<<"ok"<<endl;
sort(difference_h,difference_h+tol);
for(int i=;i<tol;i++){
SPFA(,n,difference_h[i].low,difference_h[i].high);
if(dist[n]!=INF){
printf("%d %d\n",difference_h[i].high-difference_h[i].low,dist[n]);
break;
}
}
}
return ;
}
Cycling的更多相关文章
- URAL 1966 Cycling Roads 点在线段上、线段是否相交、并查集
F - Cycling Roads Description When Vova was in Shenzhen, he rented a bike and spent most of the ...
- Aquarium Cycling
http://www.fishyou.com/aquarium-cycling.php Aquarium Cycling Aquarium cycling actually refers to the ...
- [USACO2002][poj1946]Cow Cycling(dp)
Cow CyclingTime Limit: 1000MS Memory Limit: 30000KTotal Submissions: 2468 Accepted: 1378Description ...
- Cycling Label
Cycling Label 来源: github/BBCyclingLabel Licence: Apache 2.0 作者: Bruno de Carvalho 分类: 标签(Label) 平台: ...
- Cow Cycling 动态规划
1552: Cow Cycling 时间限制(普通/Java):1000MS/10000MS 内存限制:65536KByte总提交: 39 测试通过:20 描述 The ...
- Ural 1966 Cycling Roads
================ Cycling Roads ================ Description When Vova was in Shenzhen, he rented a ...
- URAL 1966 Cycling Roads 计算几何
Cycling Roads 题目连接: http://acm.hust.edu.cn/vjudge/contest/123332#problem/F Description When Vova was ...
- cycling -avoid the vicious cycle
‘Numerous' studies in the past appear to have shown a link between cycling and ED. The researchers a ...
- UVALive - 6268 Cycling 贪心
UVALive - 6268 Cycling 题意:从一端走到另一端,有T个红绿灯,告诉你红绿灯的持续时间,求最短的到达终点的时间.x 思路:
随机推荐
- java实现excel和数据的交互
1. 环境要求 本文环境为: 数据库为oracle,jdk为jdk7,依赖jar包为ojdbc6-11.2.0.4.0.jar+poi-3.14.jar 2.POI 使用 1. 建立工作空间 2. 获 ...
- Check for Palindromes-FCC
問題: 检查回文字符串 如果给定的字符串是回文,返回true,反之,返回false. 如果一个字符串忽略标点符号.大小写和空格,正着读和反着读一模一样,那么这个字符串就是palindrome(回文). ...
- Linux学习——shell编程之环境变量配置文件
小白学习,在学习中总结! shell编程之环境变量配置文件 一:环境变量配置文件 1 shell编程之环境变量配置 变量类型: 用户自定义变量(本地变量) 环境变量 :定义每个用户的操作环境,如pat ...
- POJ 3923 Ugly Windows(——考察思维缜密性的模拟题)
题目链接: http://poj.org/problem?id=3923 题意描述: 输入一个n*m的屏幕 该屏幕内有至少一个对话框(每个对话框都有对应的字母表示) 判断并输出该屏幕内处于最表层的对话 ...
- 我修改的时钟flash
<object type="application/x-shockwave-flash" style="outline:none;" data=" ...
- TreeViewItem实现整行选中 (两种用法)
用法一 <ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation&quo ...
- cocos2dx - 环境配置,项目创建
准备工具 cocos2dx当前最新版本:v3.9 官网下载地址: http://www.cocos.com/download/ python 2.7x最新版本:2.7.11 官 ...
- git的使用(入门篇)
1.Git 的安装 Window 下的安装 从 http://git-scm.com/download 上下载window版的客户端,然后一直下一步下一步安装git即可,请注意,如果你不熟悉每个选项的 ...
- JavaEE 对象的串行化(Serialization)
什么情况下需要序列化 a)当你想把的内存中的对象写入到硬盘的时候:b)当你想用套接字在网络上传送对象的时候:c)当你想通过RMI传输对象的时候:再稍微解释一下:a)比如说你的内存不够用了,那计算机就要 ...
- Extjs6(七)——增删查改之删除
本文基于ext-6.0.0 页面就是前面写的那个,有不清楚的可以看一下前面写页面那篇. 一.在toolbar加一个删除按钮 { text:'删除', iconCls:'x-fa fa-times', ...
