hdu 2962 最短路+二分
题意:最短路上有一条高度限制,给起点和最大高度,求满足高度最大情况下,最短路的距离
不明白为什么枚举所有高度就不对
#include<cstdio>
#include<cstring>
#include<algorithm>
const int maxint=;
int c[][][],dist[],H[];
using namespace std;
int n,line;
int i,j,k;
int st,ed,mid;
int t=;
int path[];
int visit[];
bool dijkstra()
{
bool s[];
for(int i=;i<=n;i++)
{
s[i]=;
if(c[st][i][]>=mid)
dist[i]=c[st][i][];
else dist[i]=maxint;
path[i]=st;
}
s[st]=;
for(int i=;i<n;i++)
{
int temp=maxint;
int u=st;
for(int j=;j<=n;j++)
if(!s[j]&&temp>dist[j]&&c[path[j]][j][]>=mid)
{
temp=dist[j];
u=j;
}
if(temp==maxint) break;
s[u]=;
if(u==ed) return true;
for(int j=;j<=n;j++)
if(!s[j]&&c[u][j][]!=maxint&&c[u][j][]>=mid)
if(dist[j]>dist[u]+c[u][j][])
{
dist[j]=dist[u]+c[u][j][];
path[j]=u;
}
}
return false;
}
int main()
{
#ifndef ONLINE_JUDGE
freopen("1.in","r",stdin);
#endif
while(scanf("%d%d",&n,&line)!=EOF&&n&&line)
{
int tot=;
memset(H,,sizeof(H));
H[]=;
if(t) printf("\n");
printf("Case %d:\n",++t);
for(i=;i<=n;i++)
for(j=;j<=n;j++)
{
c[i][j][]=(i==j?:maxint);
c[i][j][]=-;
}
for(i=;i<=line;i++)
{
int p,q,len,h;
scanf("%d%d%d%d",&q,&p,&h,&len);
if(h==-)
{
c[p][q][]=c[q][p][]=maxint;
c[p][q][]=c[q][p][]=len;
continue;
}
if(c[p][q][]<h)
{
c[p][q][]=c[q][p][]=h;
c[p][q][]=c[q][p][]=len;
}
}
int tall;
scanf("%d%d%d",&st,&ed,&tall);
/*if(st==ed)
{
printf("maximum height = %d\n",tall);
printf("length of shortest route = 0\n");
continue;
}*/
/*H[tot++]=tall;
sort(H,H+tot);
int ans=0;
bool flag=0;
for(i=tot-1;i>=0;i--)
{
if(H[i]>tall) continue;
mid=H[i];
if(dijkstra())
{
flag=1;
ans=dist[ed];
break;
}
}*/
int first=;
int ans;
mid=(first+tall)>>;
while(first<=tall)
{
if(dijkstra())
{
ans=dist[ed];
first=mid+;
}
else
tall=mid-;
mid=(first+tall)>>;
}
if(tall==) printf("cannot reach destination\n");
else
{
printf("maximum height = %d\n",tall);
printf("length of shortest route = %d\n",ans);
}
}
return ;
}
hdu 2962 最短路+二分的更多相关文章
- HDU - 2962 Trucking SPFA+二分
Trucking A certain local trucking company would like to transport some goods on a cargo truck from o ...
- Trucking(HDU 2962 最短路+二分搜索)
Trucking Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...
- ACM: HDU 2544 最短路-Dijkstra算法
HDU 2544最短路 Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Descrip ...
- UESTC 30 &&HDU 2544最短路【Floyd求解裸题】
最短路 Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...
- POJ 3662 Telephone Lines【Dijkstra最短路+二分求解】
Telephone Lines Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 7214 Accepted: 2638 D ...
- hdu 5521 最短路
Meeting Time Limit: 12000/6000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Total ...
- poj 2391 Ombrophobic Bovines 最短路 二分 最大流 拆点
题目链接 题意 有\(n\)个牛棚,每个牛棚初始有\(a_i\)头牛,最后能容纳\(b_i\)头牛.有\(m\)条道路,边权为走这段路所需花费的时间.问最少需要多少时间能让所有的牛都有牛棚可待? 思路 ...
- Luogu P1462 通往奥格瑞玛的道路(最短路+二分)
P1462 通往奥格瑞玛的道路 题面 题目背景 在艾泽拉斯大陆上有一位名叫歪嘴哦的神奇术士,他是部落的中坚力量 有一天他醒来后发现自己居然到了联盟的主城暴风城 在被众多联盟的士兵攻击后,他决定逃回自己 ...
- HDU - 2544最短路 (dijkstra算法)
HDU - 2544最短路 Description 在每年的校赛里,所有进入决赛的同学都会获得一件很漂亮的t-shirt.但是每当我们的工作人员把上百件的衣服从商店运回到赛场的时候,却是非常累的!所以 ...
随机推荐
- go 匿名函数和闭包
匿名函数 1. 函数也是一种类型,因此可以定义作为一个函数类型的变量 package main import "fmt" // 函数作为参数 func add(a, b int) ...
- CCScale9Sprite 的 setContentSize setPreferredSize 区别
CCScale9Sprite 设置图片大小方式: updateButtonSpriteMark->setContentSize(size);//设置图片的原始大小设置节点的未转换大小.无论节点被 ...
- java基础45 IO流技术(输入字符流/缓冲输入字符流)
一.输入字符流 1.1.输入字符流体系 ------| Reader:输入字符流的基类(抽象类) ----------| FileReader:向指定文件读取数据的输入字符流(把硬盘上的数据读取到程 ...
- (四)SpringMvc文件上传
第一节:SpringMvc单文件上传 第二节:SpringMvc多文件上传
- NSPredicate用法总结(Cocoa框架中的NSPredicate用于查询,原理和用法都类似于SQL中的where,作用相当于数据库的过滤取)
简述:Cocoa框架中的NSPredicate用于查询,原理和用法都类似于SQL中的where,作用相当于数据库的过滤取. 定义(最常用到的方法): NSPredicate *ca = [NSPred ...
- 域名解析A记录与CNAME有什么区别?
A记录是直接将域名指向某个IP,如果您的主机IP不常变动就建议使用A记录.而别名解析是先将域名解析到主机别名再转跳到IP这样主机IP改变了不用重新解析.如果主机IP常变建议用别名解析 A记录正规些.独 ...
- 【BZOJ】4671: 异或图
题解 写完之后开始TTTTTTT--懵逼 这道题我们考虑一个东西叫容斥系数啊>< 这个是什么东西呢 也就是\(\sum_{i = 1}^{m}\binom{m}{i}f_{i} = [m ...
- 【LOJ】#2292. 「THUSC 2016」成绩单
题解 神仙dp啊><(也有可能是我菜) 我们发现,想要拿一段区间的话,只和这个区间的最大值和最小值有关系,那么我们考虑,如果一个区间[l,r]我们拿走了一些数后,使它的最小值是a,最大值是 ...
- JS 如何准确获取当前页面URL网址信息
在WEB开发中,时常会用到javascript来获取当前页面的url网址信息,在这里是一些获取url信息的小总结. 下面我们举例一个URL,然后获得它的各个组成部分:http://i.cnblogs. ...
- Linq To Sql 使用初探
最近有数据处理需要,就是那种从数据库中把数据取出来 ,对其中的部分字段做一些处理再吐回去的工作,从同事那里学习到了,这中活最适合使用 Linq to Sql 这种方式,不用搭建框架,不用自建实体,直接 ...