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.但是每当我们的工作人员把上百件的衣服从商店运回到赛场的时候,却是非常累的!所以 ...
随机推荐
- 【算法学习】【洛谷】cdq分治 & P3810 三维偏序
cdq是何许人也?请参看这篇:https://wenku.baidu.com/view/3b913556fd0a79563d1e7245.html. 在这篇论文中,cdq提出了对修改/询问型问题(Mo ...
- 【技巧总结】Penetration Test Engineer[3]-Web-Security(SQL注入、XXS、代码注入、命令执行、变量覆盖、XSS)
3.Web安全基础 3.1.HTTP协议 1)TCP/IP协议-HTTP 应用层:HTTP.FTP.TELNET.DNS.POP3 传输层:TCP.UDP 网络层:IP.ICMP.ARP 2)常用方法 ...
- 【Python项目】爬取新浪微博签到页
基于微博签到页的微博爬虫 项目链接:https://github.com/RealIvyWong/WeiboCrawler/tree/master/WeiboLocationCrawler 1 实现功 ...
- PHP 生成、识别二维码及安装相关扩展/工具
2018-02-20 00:30:26 更新:推荐新扩展(极力推荐) 这篇文章里用的两个二维码扩展都有些问题和麻烦:phpqrcode(生成二维码)的源码有点小 bug: 而 php-zbarcod ...
- F5后端nginx+tomcat应用如何获得用户的真实ip【转】
根据业务需要要求记录每个通过wap或者客户端访问我们服务器的用户真实ip但是由于业务前端部署了两个3900系列的F5设备导致程序一直获得F5设备自身的ip,所以笔者考虑可能是因为F5导致无法获得用户的 ...
- C#基础学习之FileStream
FileStream和File的区别 后者比前者给内存带来压力大. FileStream可以操作字节也就是可以保存任何类型的文件. 1.FileStream读文件操作 //OpenOrCreate: ...
- 24 The Go image package go图片包:图片包的基本原理
The Go image package go图片包:图片包的基本原理 21 September 2011 Introduction The image and image/color packag ...
- 数据库-mysql安装
MySQL 安装 所有平台的Mysql下载地址为: MySQL 下载. 挑选你需要的 MySQL Community Server 版本及对应的平台. Linux/UNIX上安装Mysql Linux ...
- python网络编程--RabbitMQ
一:RabbitMQ介绍 RabbitMQ是AMPQ(高级消息协议队列)的标准实现.也就是说是一种消息队列. 二:RabbitMQ和线程进程queue区别 线程queue:不能跨进程,只能用于多个线程 ...
- 洛谷P2024食物链
传送门啦 这道题的特殊之处在于对于任意一个并查集,只要告诉你某个节点的物种,你就可以知道所有节点对应的物种. 比如一条长为4的链 甲->乙->丙->丁 ,我们知道乙是A物种.那么甲一 ...