博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[BZOJ2654]tree(二分+Kruskal)
阅读量:4591 次
发布时间:2019-06-09

本文共 1262 字,大约阅读时间需要 4 分钟。

2654: tree

Time Limit: 30 Sec  Memory Limit: 512 MB
Submit: 2733  Solved: 1124
[][][]

Description

给你一个无向带权连通图,每条边是黑色或白色。让你求一棵最小权的恰好有need条白色边的生成树。
题目保证有解。

 

Input

第一行V,E,need分别表示点数,边数和需要的白色边数。
接下来E行,每行s,t,c,col表示这边的端点(点从0开始标号),边权,颜色(0白色1黑色)。

 

Output

一行表示所求生成树的边权和。
V<=50000,E<=100000,所有数据边权为[1,100]中的正整数。

 

 

Sample Input

2 2 1
0 1 1 1
0 1 2 0

Sample Output

2

HINT

 

原数据出错,现已更新 by liutian,但未重测---2016.6.24

 

Source

 
[ ][ ][ ]

一种叫WQS二分的思想,据说[九省联考2018]林克卡特树用到了这个东西。

但是这道题不看论文也可以直接做,将每条白边加上x后求MST,设树上的白边的个数为f(x),可以确定f(x)是单调不增的,二分即可。

但可能f(mid)>k,f(mid+1)<k,我们把相同长度的白边放在黑边的前面即可。

1 #include
2 #include
3 #define rep(i,l,r) for (int i=l; i<=r; i++) 4 typedef long long ll; 5 using namespace std; 6 7 const int N=100100; 8 int n,m,cnt,tot,k,ans,u[N],v[N],w[N],c[N],fa[N]; 9 struct E{ int u,v,w,c; }e[N];10 11 bool operator<(E a,E b){ return a.w==b.w ? a.c
=k;30 }31 32 int main(){33 scanf("%d%d%d",&n,&m,&k);34 rep(i,1,m) scanf("%d%d%d%d",&u[i],&v[i],&w[i],&c[i]),u[i]++,v[i]++;35 int L=-105,R=105;36 while(L<=R){37 int mid=(L+R)>>1;38 if(check(mid)) L=mid+1,ans=tot-k*mid; else R=mid-1;39 }40 printf("%d\n",ans);41 return 0;42 }

 

转载于:https://www.cnblogs.com/HocRiser/p/8809347.html

你可能感兴趣的文章
C++语言基础(16)-string类
查看>>
Using IntelliJ IDEA as the Vim Editor
查看>>
js中typeOf用法
查看>>
centos7.2 apache 绑定二级目录 访问依然是apache页面
查看>>
jquery 编程的最佳实践
查看>>
MeetMe
查看>>
IP报文格式及各字段意义
查看>>
(转载)rabbitmq与springboot的安装与集成
查看>>
C2. Power Transmission (Hard Edition)(线段相交)
查看>>
STM32F0使用LL库实现SHT70通讯
查看>>
Atitit. Xss 漏洞的原理and应用xss木马
查看>>
MySQL源码 数据结构array
查看>>
(文件过多时)删除目录下全部文件
查看>>
T-SQL函数总结
查看>>
python 序列:列表
查看>>
web移动端
查看>>
5. Longest Palindromic Substring (DP)
查看>>
sql语句一些简单的用法
查看>>
HDU 5934 Bomb(炸弹)
查看>>
领域驱动设计之聚合与聚合根实例一
查看>>