bzoj 2654 tree 二分+kruskal

本文介绍了一个无向带权连通图中寻找恰好包含特定数量白色边的最小生成树的方法。通过二分查找优化白边成本,并使用并查集确定生成树,解决了权值相等的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

tree

Time Limit: 30 Sec  Memory Limit: 512 MB
Submit: 2739  Solved: 1126
[Submit][Status][Discuss]

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

 
题解:get了一种新的套路,可以二分一个值,让白边都减去这个值,然后排序后,可以发现这样具有二分性
   然后可以瞎搞,不过注意权值相等的问题,所以每次需要加的是二分值的的贡献。
 1 #include<cstring>
 2 #include<cstdio>
 3 #include<algorithm>
 4 #include<iostream>
 5 #include<cmath>
 6 #include<queue>
 7 
 8 #define N 50007
 9 #define M 100007
10 using namespace std;
11 inline int read()
12 {
13     int x=0,f=1;char ch=getchar();
14     while(!isdigit(ch)){if(ch=='-')f=-1;ch=getchar();}
15     while(isdigit(ch)){x=(x<<1)+(x<<3)+ch-'0';ch=getchar();}
16     return x*f;
17 }
18 
19 int n,m,ned;
20 int ans,num;
21 int fa[N];
22 struct Node
23 {
24     int x,y,w,c;
25     friend bool operator<(Node x,Node y)
26     {
27         if (x.w==y.w) return x.c<y.c;
28         return x.w<y.w;
29     }
30 }a[M],e[M];
31 
32 int find(int num)
33 {
34     if (fa[num]!=num) fa[num]=find(fa[num]);
35     return fa[num];
36 }
37 bool judge(int zhi)
38 {
39     ans=0,num=0;
40     for (int i=1;i<=m;i++)
41     {
42         e[i]=a[i];
43         if (!a[i].c) e[i].w+=zhi;
44     }
45     sort(e+1,e+m+1);
46     for (int i=1;i<=n;i++) fa[i]=i;
47     for (int i=1;i<=m;i++)
48     {
49         int u=find(e[i].x),v=find(e[i].y);
50         if (u!=v)
51         {
52             fa[v]=u;
53             if (!e[i].c) num++;
54             ans+=e[i].w;
55         }
56     }
57     ans-=zhi*num;
58     if (num>=ned) return true;
59     else return false;
60 }
61 int main()
62 {
63     n=read(),m=read(),ned=read();
64     for (int i=1;i<=m;i++)
65         a[i].x=read()+1,a[i].y=read()+1,a[i].w=read(),a[i].c=read();
66     
67     int l=-105,r=105;
68     while(l<r)
69     {
70         int mid=(l+r+1)>>1;
71         if (judge(mid)) l=mid;
72         else r=mid-1;
73     }
74     printf("%d\n",ans);
75 }

 

转载于:https://www.cnblogs.com/fengzhiyuan/p/8847767.html

资源下载链接为: https://pan.quark.cn/s/1f197bf22c2c 随着疫情防控形势的复杂多变,防疫物资的高效管理成为保障社会正常运转的关键环节。传统管理方式存在效率低、信息不透明等问题,难以满足现代疫情防控的动态需求。因此,开发一套基于现代化信息技术的防疫物资管理系统具有重要的现实意义。 本研究旨在通过构建一套高效的防疫物资管理系统,实现物资信息的实时更新与精准管理,提高物资调配效率,降低管理成本,为疫情防控工作提供有力支持,同时为相关领域的信息化建设提供参考借鉴。 本研究将围绕防疫物资管理系统的设计与实现展开,包括系统需求分析、系统设计、系统实现以及系统测试等环节,重点解决系统功能模块的开发与优化问题。 Eclipse是一款功能强大的集成开发环境,支持多种编程语言,为本系统开发提供了便捷的代码编写与调试工具。 JSP(Java Server Pages)是一种基于Java的动态网页技术,能够实现页面内容的动态生成,为系统的用户界面展示提供了技术支持。 B/S(浏览器/服务器)结构是一种网络应用架构,用户通过浏览器访问服务器上的应用程序,具有易于部署、维护方便等优点,适用于本系统的网络环境。 MySQL是一种开源关系型数据库管理系统,具有高性能、高可靠性和易用性等特点,为系统的数据存储与管理提供了可靠的解决方案。 Tomcat是一个开源的Java Servlet容器,支持JSP和Servlet技术,能够高效地运行Java Web应用程序,是本系统运行的重要支撑平台。 当前信息技术的快速发展为本系统的开发提供了成熟的技术基础,相关技术的稳定性和兼容性能够满足系统开发的需求。 系统开发所需的技术资源和硬件设备成本相对较低,且能够有效降低防疫物资管理的运营成本,具有良好的经济可行性。 系统能够提高防疫物资管理的效率和透明度,符合社会对疫情防控工作的需求,具
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值