题意:最短路上有一条高度限制,给起点和最大高度,求满足高度最大情况下,最短路的距离

不明白为什么枚举所有高度就不对

 #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 最短路+二分的更多相关文章

  1. HDU - 2962 Trucking SPFA+二分

    Trucking A certain local trucking company would like to transport some goods on a cargo truck from o ...

  2. Trucking(HDU 2962 最短路+二分搜索)

    Trucking Time Limit: 20000/10000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  3. ACM: HDU 2544 最短路-Dijkstra算法

    HDU 2544最短路 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Descrip ...

  4. UESTC 30 &&HDU 2544最短路【Floyd求解裸题】

    最短路 Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...

  5. POJ 3662 Telephone Lines【Dijkstra最短路+二分求解】

    Telephone Lines Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 7214   Accepted: 2638 D ...

  6. hdu 5521 最短路

    Meeting Time Limit: 12000/6000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others)Total ...

  7. poj 2391 Ombrophobic Bovines 最短路 二分 最大流 拆点

    题目链接 题意 有\(n\)个牛棚,每个牛棚初始有\(a_i\)头牛,最后能容纳\(b_i\)头牛.有\(m\)条道路,边权为走这段路所需花费的时间.问最少需要多少时间能让所有的牛都有牛棚可待? 思路 ...

  8. Luogu P1462 通往奥格瑞玛的道路(最短路+二分)

    P1462 通往奥格瑞玛的道路 题面 题目背景 在艾泽拉斯大陆上有一位名叫歪嘴哦的神奇术士,他是部落的中坚力量 有一天他醒来后发现自己居然到了联盟的主城暴风城 在被众多联盟的士兵攻击后,他决定逃回自己 ...

  9. HDU - 2544最短路 (dijkstra算法)

    HDU - 2544最短路 Description 在每年的校赛里,所有进入决赛的同学都会获得一件很漂亮的t-shirt.但是每当我们的工作人员把上百件的衣服从商店运回到赛场的时候,却是非常累的!所以 ...

随机推荐

  1. Shell-修改MySQL默认root密码

    Code: mysqltmppwd=`cat /tmp/.mysql_secret | cut -b 87-102` mysqladmin -u root -p${mysqltmppwd} passw ...

  2. mysql -> 备份与恢复_11

    备份恢复原理 逻辑备份 物理备份 备份工具

  3. 牛x的JavaScript编辑器你知道几个

    英文:Martin Heller  译文:葡萄城控件 学习过程中遇到什么问题或者想获取学习资源的话,欢迎加入学习交流群343599877,我们一起学前端! 对于JavaScript程序员来说,目前有很 ...

  4. sql loader 控制文件使用十六进制分隔符

    最近项目中使用到了sql loader加载数据文件至数据库,提供的文件中使用了十六进制 7F5E 分隔符,在sql loader中如何加载呢? 经过查询实验后,控制文件ctl内容如下: load da ...

  5. CCScale9Sprite 的 setContentSize setPreferredSize 区别

    CCScale9Sprite 设置图片大小方式: updateButtonSpriteMark->setContentSize(size);//设置图片的原始大小设置节点的未转换大小.无论节点被 ...

  6. 正则表达式之你不知道的replace

    我们都知道js内置类String提供了一个replace方法,可以把指定字符串替换为另一个字符串,他的基础用法如下: var str="hello world"; var str= ...

  7. 使用插件实现Jenkins参数化构建

    一.插件安装 1.打开插件管理,在此界面可以安装插件 二.参数化 1.在“可选插件”中查找如下两个插件然后安装,安装后重启Jenkins Build With Parameters 输入框式的参数 P ...

  8. Centos7配置vsftpd3.0.2

    1.安装vsftpd vsftp使用本地用户登陆方式 yum -y install vsftpd yum安装的版本3.0.2 2.配置vsftpd vim /etc/vsftpd/vsftpd.con ...

  9. 容器计划任务大坑:在alpine容器里,想用非root帐号执行crontab任务

    我只能说抱歉,我前前后后测试了七天, 将自己预想的配置错误,一个一个去验证. 非root帐号在alpine容器里执行crontab任务,还是失败, 输出依旧是一片空白~ stackoverflow里, ...

  10. Java学习(异常类练习题)

     练习题: 1.计算圆的面积,半径不能为零和负数 package com.oracle.Demo01; public class Demo02 { // 写一个计算圆的面积的方法,传一个半径,返回面积 ...