USACO 2008 January Silver Telephone Lines /// 二分最短路 邻接表dijkstra oj22924
题目大意:
一共有N (1 ≤ N ≤ 1,000)个电线杆,有P P (1 ≤ P ≤ 10,000)对电线杆是可以连接的,
用几条线连接在一起的电线杆之间都可相互通信,现在想要使得电线杆1和电线杆N能相互通信,
并且电线公司提出KK (0 ≤ K < N)条电线是可以免费使用的,
当使用电线的数量超过K条,超出的电线要收费,
收的总费用为去掉免费使用的K条电线之后最长的那条电线的长度。
问最少费用是多少
* Line 1: Three space-separated integers: N, P, and K
* Lines 2..P+1: Line i+1 contains the three space-separated integers: Ai, Bi, and Li
Line 1: A single integer, the minimum amount Farmer John can pay. If it is impossible to connect the farm to the phone company, print -1.
5 7 1
1 2 5
3 1 4
2 4 8
3 2 3
5 2 9
3 4 7
4 5 6
4
/*
这题二分猜测答案 用最短路dijkstra验证 验证 猜测的mid是1~N的最短路中第k+1大的花费
用dis[i]记录1到i点时 花费>= mid 的顶点数 //若1~N没有路 则dis[n]始终为初始值INF
//则二分猜测的答案始终正确 最终二分会被推到最右的点
即无路 输出-1 //若1~N有路但小于k+1条 则dis[n]始终<k+1
//则二分猜测的答案始终错误 最终二分会被推到最左的点
即无花费 输出0 */ #include <bits/stdc++.h>
#define INF 0x3f3f3f3f
using namespace std;
struct NODE
{ /// 要放在vector里 需要重载小于号 按 val即花费 升序排序
int to,val; // 到to点 花费val
bool operator<(const NODE& x) const
{ return val < x.val; }
};
vector <NODE> vec[];
int n,p,k,vis[],dis[];
bool dijk(int mid)
{
for(int i=;i<=n;i++)
vis[i]=, dis[i]=INF; priority_queue <NODE> q; ///优先队列自动升序排序
NODE e; e.to=,e.val=;
q.push(e); dis[]=; while(!q.empty())
{
e=q.top(); q.pop();
vis[e.to]=;
vector <NODE> ::iterator it;
for(it=vec[e.to].begin();it!=vec[e.to].end();it++)
{
NODE tmp=*it;
if(vis[tmp.to]) continue;
int nowv=dis[e.to]+ (tmp.val>=mid ? :);
/// tmp.val>=mid的话 说明在这条路上 到顶点tmp.to的路大于猜测值
/// 则dis[该点]为dis[上一点]+1 否则+0 先用nowv记录 /// 与答案mid相等的也记录下来 若mid为正确答案 则恰好为第k+1个
/// 可能有多个花费等于mid 所以判断dis[n]>=k+1 if(dis[tmp.to]>nowv)
{/// 之前记录过的比nowv大 说明nowv所在的这条才是较短的路
dis[tmp.to]=nowv;
vis[tmp.to]=;
q.push(tmp);
}
}
}
//printf("%d\n",dis[n]);
return dis[n]>=k+;
}
int main()
{
while(~scanf("%d%d%d",&n,&p,&k))
{
for(int i=;i<=n;i++)
vec[i].clear(); NODE e;
while(p--)
{
int a,b,c;
scanf("%d%d%d",&a,&b,&c);
e.to=b, e.val=c;
vec[a].push_back(e);
e.to=a, e.val=c;
vec[b].push_back(e);/// 无向图邻接表
} int le=,rig=,ans=-;
while(le<=rig)
{// 二分答案 mid为猜测值 进入dijk()验证 mid是不是第k+1条路
int mid=(le+rig)/;
if(spfa(mid)) le=mid+, ans=mid; ///mid在k个之后(太小或恰好)
else rig=mid-; ///mid在k个之内(太大) 缩小范围继续验证
}
if(ans>) ans=-; /// 说明dis[n] 一直在k个之后
if(rig<) ans=; /// 说明dis[n] 一直在k个之内
printf("%d\n",ans);
} return ;
}
USACO 2008 January Silver Telephone Lines /// 二分最短路 邻接表dijkstra oj22924的更多相关文章
- POJ 3662 Telephone Lines(二分+最短路)
查看题目 最小化第K大值. 让我怀疑人生的一题目,我有这么笨? #include <cstdio> #include <queue> #include <cstring& ...
- poj3662 Telephone Lines【最短路】【二分】
http://poj.org/problem?id=3662 Telephone Lines Time Limit: 1000MS Memory Limit: 65536K Total Submi ...
- poj 3662 Telephone Lines(最短路+二分)
Telephone Lines Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 6973 Accepted: 2554 D ...
- [USACO 2008 Jan. Silver]架设电话线 —— 最短路+二分
一道图论的最短路题.一开始连最短路都没想到,可能是做的题太少了吧,完全没有思路. 题目大意: FJ的农场周围分布着N根电话线杆,任意两根电话线杆间都没有电话线相连.一共P对电话线杆间可以拉电话线,第i ...
- poj-3662 Telephone Lines 二分答案+最短路
链接:洛谷 POJ 题目描述 Farmer John wants to set up a telephone line at his farm. Unfortunately, the phone co ...
- POJ 3662 Telephone Lines (二分+Dijkstra: 最小化第k大的值)
题意 Farmer John想从电话公司修一些电缆连接到他农场.已知N个电线杆编号为1,2,⋯N,其中1号已经连接电话公司,N号为农场,有P对电线杆可连接. 现给出P对电线杆距离Ai,Bi,Li表示A ...
- POJ 3662 Telephone Lines (二分+dijkstra)
题意: 多年以后,笨笨长大了,成为了电话线布置师.由于地震使得某市的电话线全部损坏,笨笨是负责接到震中市的负责人. 该市周围分布着N(1<=N<=1000)根据1……n顺序编号的废弃的电话 ...
- POJ-3662 Telephone Lines 二分+双端队列
题目传送门 题意:有n个点, p条路,每条道路有个花费Li, 然后现在要建一条1-n的路线,然后可以选k条道路免费, 然后可以在剩下的道路中选择价格最高的边支付费用, 求这个答案最小. 题解: 二分答 ...
- USACO 2008 Mar Silver 3.River Crossing 动态规划水题
Code: #include<cstring> #include<algorithm> #include<cstdio> using namespace std; ...
随机推荐
- Ethenet: MAC PHY MII RMII
https://www.cnblogs.com/liangxiaofeng/p/3874866.html 1. general 下图是网口结构简图.网口由CPU.MAC和PHY三部分组成.DMA控制器 ...
- yum设置代理
echo "proxy=http://[proxy_url]:8080" >> /etc/yum.conf
- Cuckoo架构
cuckoo在部署阶段,只在Guest系统里塞了一个agent,这个agent在运行阶段负责与Host端程序进行通信,从Host端接收sample, 整个客户端程序,以及配置文件. 在Host端主要的 ...
- vim + ctag + Taglist (转)
一.ctag 当然,第一步就是要下载它!一条命令搞定: $sudo apt-get install ctags 如果不幸提示找不到软件包ctags,首先你也许应该update一下你的软件源,还不行的话 ...
- Webpack4篇
[Webpack4篇] webpack4 打包优化策略 当前依赖包的版本 1 优化loader配置 1.1 缩小文件匹配范围(include/exclude) 通过排除node_modules下的文件 ...
- 第三记 Java面向对象
相信很多人都有听到,见到这么一句话:Java是一门面向对象编程的语言,但是又是否对这句话有了自己的理解呢? 一.面向对象 面向对象是一种新兴的程序设计方法,也可以说是一种新的程序设计规范(paradi ...
- python全栈开放实践第三版第一章的练习题完成情况
练习题: 1.简述编译型与解释型语言的区别,且分别列出你知道哪些语言属于编译型,哪些数以解释型.1 编译型:只须编译一次就可以把源代码编译成机器语言,后面的执行无须重新编译,直接使用之前的编译结果就可 ...
- 2019ICPC南京网络赛B super_log
题意:求a的a的a次方..一直求b次,也就是在纸上写个a,然后一直a次方a次方,对m取模,记为F(a,b,m)=pow(a,F(a,b-1,phi(m)) 解题思路:联系欧拉降幂,这个迭代的过程,我们 ...
- linux 下无法输入# 显示为£
在键盘布局里面,(Keyboard Layout)设置为中国,汉语.解决问题
- 从零开始搭建系统2.1——Nexus安装及配置
在安装配置Nexus时,请先确定您已经配置好jdk 1.创建目录 2.下载安装包 [root@localhost usr]# cd nexus 下载地址:https://www.sonatype.co ...