【二分】【SPFA】架设电话线(jzoj 2132)

架设电话线

jzoj 2132

题目大意:

给你一个图,让你从1走到n,问如果可以使k条路的代价变为0(自选),那途中走的路的最大值最小是多少

样例输入

5 7 1
1 2 5
3 1 4
2 4 8
3 2 3
5 2 9
3 4 7
4 5 6

输入说明:

一共有5根废弃的电话线杆。电话线杆1不能直接与电话线杆4、5相连。电话线杆5不能直接与电话线杆1、3相连。其余所有电话线杆间均可拉电话线。电信公司可以免费为FJ连结一对电话线杆。

样例输出

4

输出说明:

FJ选择如下的连结方案:1->3;3->2;2->5,这3对电话线杆间需要的电话线的长度分别为4、3、9。FJ让电信公司提供那条长度为9的电话线,于是,他所需要购买的电话线的最大长度为4。

数据范围

1⩽K⩽N⩽1,0001 \leqslant K\leqslant N \leqslant 1,0001KN1,000
1⩽P⩽10,0001 \leqslant P\leqslant 10,0001P10,000
1⩽Li⩽1,000,0001 \leqslant L_i \leqslant 1,000,0001Li1,000,000
n为点的总数,p为路的总数,l为路的权值,K如题目大意所叙

解题思路:

我们可以先二分答案,然后把权值大于midmidmid的路设为1,然后跑spfa,如果结果小于k就说明可行

代码:

#include<queue>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
int n,m,k,x,y,z,l,r,pd,mid,tot,top,head[1500],b[1500],p[1500],s[10500],pp[1000500];
struct rec
{int to,l,next;
}a[20500];
int js(int aa,int bb){return aa>bb?1:0;}//大于条件的就是1
int spfa(int maxx)
{memset(b,127/3,sizeof(b));//预处理memset(p,0,sizeof(p));queue<int>d;d.push(1);p[1]=1;b[1]=0;while(!d.empty())//spfa{int h=d.front();d.pop();for (int i=head[h];i;i=a[i].next)if (b[h]+js(a[i].l,maxx)<b[a[i].to]){b[a[i].to]=b[h]+js(a[i].l,maxx);if (!p[a[i].to]){p[a[i].to]=1;d.push(a[i].to);}}p[h]=0;}if (b[n]==b[0]) return 0;//无解else if (b[n]<=k) return 1;//可行else return 2;//不可行
}
int main()
{scanf("%d %d %d",&n,&m,&k);for (int i=1;i<=m;++i){scanf("%d %d %d",&x,&y,&z);a[++tot].to=y;//存边a[tot].l=z;a[tot].next=head[x];head[x]=tot;a[++tot].to=x;a[tot].l=z;a[tot].next=head[y];head[y]=tot;if (!pp[z]) s[++top]=z;//把所有的权值存进来,用于二分}s[++top]=0;//为了处理k>最小边数sort(s+1,s+1+top);//排序l=1;r=top;while(l<r){mid=(l+r)>>1;//求中间值pd=spfa(s[mid]);if (!pd) {printf("-1");return 0;}else if (pd&1) r=mid;else l=mid+1;}printf("%d",s[l]);
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/320553.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

HDU5528 - Count a * b

HDU5528 - Count a * b 做法&#xff1a;求\(\sum_{m|n}(m^2 - \sum_{i1}^{m}\sum_{j1}^m [m|(ij)])\) \(h(m) \sum_{i1}^{m}\sum_{j1}^m [m|(ij)] \sum_{i1}^m\sum_{j1}^m [\frac{m}{(i,m)}|\frac{i}{(i,m)}j]\) $ \sum_{i1}^m\sum_{j1}^m [\frac{m}{(i,m)}|j] \sum_{i1}^…

CodeForces - 1189B Number Circle

原题传送器<----点我 **题意&#xff1a;**n个数字&#xff0c;请你给它们排个序围成一个环&#xff0c;满足任意一个数两边的数之和大于它本身&#xff0c;例如题目给的图&#xff08;左图为正确答案&#xff09;&#xff0c;如果不存在这样的环就输出NO。 难度★ 题解 …

P7044-[MCOI-03]括号【组合数学】

正题 题目链接:https://www.luogu.com.cn/problem/P7044?contestId36089 题目大意 一个括号序列&#xff0c;0级偏值定义为其中不合法的括号数量。 kkk级偏值定义为它所有子串的k−1k-1k−1级偏值的和。 求这个括号序列的kkk级偏值。 解题思路 后文中我们定义G(x,y)Cxy−1y…

在 .NET Core 应用中使用 NHibernate

NHibernate 最近发布了 5.1.3 版本&#xff0c; 支持 .NET Standard 2.0 &#xff0c; 这意味着可以在 .NET Core 2.0 应用中使用&#xff0c; 本文就已 WebAPI 应用为例&#xff0c; 介绍一下如何在 .NET Core 应用中如何使用 NHibernate 。1、 新建一个基于 .NET Core 的 We…

牛客网【每日一题】3月25日 tokitsukaze and Soldier

牛客网【每日一题】3月25题号&#xff1a;NC50439 名称&#xff1a; tokitsukaze and Soldier 来源&#xff1a;练习赛50-C 链接: link. 来源&#xff1a;牛客网 时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒 空间限制&#xff1a;C/C 524288K&#xff0c;其他语言10…

GYM101002C - Greetings!

GYM101002C - Greetings! 做法&#xff1a;\(dp[i][S]\)表示用了\(i\)种信封&#xff0c;明信片的状态为\(S\)时的最小花费&#xff0c;预处理\(A[S]\)表示可以装的对应明信片的集合的花费, \(dp[i][s] min(dp[i-1][s-s2] A[s2]), s2 \in s\)。注意枚举所有子集&#xff0c;再…

P7045-[MCOI-03]金牌【构造,交互题】

正题 题目链接:https://www.luogu.com.cn/problem/P7045?contestId36089 题目大意 nnn个物品有一些颜色&#xff0c;可以询问QQQ次两个物品的颜色是否相同&#xff0c;求一个排列是的相邻的物品颜色不同。其中Q≥2n−2Q\geq 2n-2Q≥2n−2 解题思路 对于每一个不在头尾的物品…

【数学】礼物(jzoj 2129)

礼物 jzoj 2129 题目大意 有1……n,n个礼物盒&#xff0c;第i个礼物盒有i个礼物&#xff0c;现在让你选2个礼物盒&#xff0c;使他是k的倍数 输入样例 1 1 3 2 5 2 50 50 0 0输出样例 0 1 4 24数据范围 20%的数据N<100; 80%的数据K<1000; 每个输入文件最多有200行…

微信小程序与AspNetCore SignalR聊天实例

微信小程序与aspnetcore signalr实例本文不对小程序与signalr做任何介绍,默认读者已经掌握aspnetcore Signalr文档小程序文档写在之前SignalR没有提供小程序使用的客户端js,所以本人参考signlar.js写了小程序版signalr-client.js 代码开源&#xff0c;地址 https://github.com/…

二次重建基本完成辣!

二次重建基本完成辣&#xff01; 实现了一些&#xff0c;之前觉得很有意思的设想&#xff0c;参考了许多dalao的blog解决了手机端突然出现的无法点击链接的问题但是在由于css实现过程中&#xff0c;本人姿势水平不够&#xff0c;Pad和手机无法正常显示。。。适配调整工程过于庞…

纪中C组模拟赛总结(2019.7.12)

成绩&#xff1a; rankrankrank是有算其他dalaodalaodalao的 rankrankranknamenamenamescorescorescoreT1T1T1T2T2T2T3T3T3T4T4T4444tjhtjhtjh127.7127.7127.72020200001001001007.77.77.7555lthlthlth120120120202020000100100100000888lyflyflyf107.7107.7107.70000001001001…

牛客网【每日一题】3月26日 合并回文子串

题号&#xff1a;NC13230 名称&#xff1a;合并回文子串 来源&#xff1a;美团2017年CodeM大赛-初赛A轮 题目链接 时间限制&#xff1a;C/C 2秒&#xff0c;其他语言4秒 空间限制&#xff1a;C/C 262144K&#xff0c;其他语言524288K 64bit IO Format: %lld 题目描述 输入两个字…

jzoj5363-[NOIP2017提高A组模拟9.14]生命之树【启发式合并,Trie】

正题 题目大意 nnn个点的一棵树&#xff0c;每个节点有一个值valvalval和一个字符串SSS。对于每个点求∑x∈decp∑y∈decp(x<y)(valxxorvaly)∗∣LCP(Sx,Sy)∣\sum_{x\in dec_p}\sum_{y\in dec_p(x<y)}(val_x\ xor\ val_y)*|LCP(S_x,S_y)|x∈decp​∑​y∈decp​(x<y)…

技术绩效考量:你们可能都做错了

欢迎来到通向卓越之路&#xff01;我们或许都陷入了这样的困境&#xff0c;我们努力成为卓越的企业&#xff0c;我们进行绩效考量&#xff0c;并在此过程中找到正确的OKR、KPI或ABC。但这可能是一件很困难的事情&#xff0c;特别是当我们所在的组织非常复杂并从技术幽灵&#x…

UVALive 8518 - Sum of xor sum

UVALive 8518 - Sum of xor sum 做法&#xff1a;线段树维护&#xff1a;答案&#xff0c;边界在左端点的区间异或为1的个数&#xff0c;边界在右端点异或为1的个数&#xff0c;1的个数&#xff0c;区间长度&#xff0c;这样已经自洽了。&#xff08;每次讲线段树&#xff0c;都…

【结论】取石子游戏(jzoj 1211)

取石子游戏 jzoj 1211 题目大意&#xff1a; 有n个石子&#xff0c;每次可取1~k个石子&#xff08;必须取&#xff09;&#xff0c;问先取者是否有必胜方法 输入样例 2 2 3 3 2输出样例 No Yes数据范围 20%的数据 K≤10 N≤30,000,000 50%的数据 K≤100 N≤2^31-1 100%的…

CodeForces 282E Sausage Maximization(trie+xor)

传送题目 看了半个多小时的题解才搞明白&#xff0c;一下题解为自己的心得 参考博客&#xff08;这两个讲的很详细&#xff09;&#xff1a; 参考一 参考二 题意&#xff1a;有一个长度有n的整数序列&#xff0c;你要在这个序列中选择一个前缀和后缀&#xff0c;前后缀不想交&a…

Net Core平台灵活简单的日志记录框架NLog+Mysql组合初体验

Net Core平台灵活简单的日志记录框架NLog初体验前几天分享的"[Net Core集成Exceptionless分布式日志功能以及全局异常过滤][https://www.cnblogs.com/yilezhu/p/9339017.html]" 有人说比较重量&#xff0c;生产环境部署也比较麻烦。因此就有了今天的这篇文章。如果你…

jzoj5365-[GDOI2018模拟9.14]通信【线段树合并】

正题 题目大意 nnn个节点的一棵树&#xff0c;随机选择一个区间&#xff0c;求这个区间的点所构成的虚树的期望权值和。 解题思路 考虑每一条边的贡献&#xff0c;定义一边的点为黑点&#xff0c;一边的为白点&#xff0c;显然包含黑白的区间都会产生贡献。考虑减去没有贡献的…

HDU5129 - Yong Zheng's Death

HDU5129 - Yong Zhengs Death 做法&#xff1a;看题之后&#xff0c;就想到要建好trie树&#xff0c;然后输出非根节点数的平方&#xff0c;这样显然错了。因为会出现重算的情况&#xff0c;即&#xff1a;你有 ab,cde ,abc,de, abcd, e,这几个串那么 [ab, cde] [abc,de] [abcd…