热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

[BZOJ2654]Tree问题:二分查找与Kruskal算法结合的优化解决方案

题目《BZOJ2654:Tree》的时间限制为30秒,内存限制为512MB。该问题通过结合二分查找和Kruskal算法,提供了一种高效的优化解决方案。具体而言,利用二分查找缩小解的范围,再通过Kruskal算法构建最小生成树,从而在复杂度上实现了显著的优化。此方法不仅提高了算法的效率,还确保了在大规模数据集上的稳定性能。

2654: tree

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

Description

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

 

Input

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

 

Output

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

 

 

Sample Input

2 2 1
0 1 1 1
0 1 2 0

Sample Output

2

HINT

 

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

 

Source

[Submit][Status][Discuss]

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

tsinsen.com/resources/Train2012-sol-wqs.pdf

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

但可能f(mid)>k,f(mid&#43;1)

https://www.cnblogs.com/NaVi-Awson/p/7252243.html

1 #include
2 #include
3 #define rep(i,l,r) for (int i&#61;l; i<&#61;r; i&#43;&#43;)
4 typedef long long ll;
5 using namespace std;
6
7 const int N&#61;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&#61;&#61;b.w ? a.cb.w; }
12 int find(int x){ return x&#61;&#61;fa[x] ? x : fa[x]&#61;find(fa[x]); }
13
14 bool check(int x){
15 tot&#61;cnt&#61;0;
16 rep(i,1,n) fa[i]&#61;i;
17 rep(i,1,m){
18 e[i].u&#61;u[i]; e[i].v&#61;v[i]; e[i].w&#61;w[i]; e[i].c&#61;c[i];
19 if(!c[i])e[i].w&#43;&#61;x;
20 }
21 sort(e&#43;1,e&#43;m&#43;1);
22 rep(i,1,m){
23 int p&#61;find(e[i].u),q&#61;find(e[i].v);
24 if(p!&#61;q){
25 fa[p]&#61;q; tot&#43;&#61;e[i].w;
26 if (!e[i].c) cnt&#43;&#43;;
27 }
28 }
29 return cnt>&#61;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]&#43;&#43;,v[i]&#43;&#43;;
35 int L&#61;-105,R&#61;105;
36 while(L<&#61;R){
37 int mid&#61;(L&#43;R)>>1;
38 if(check(mid)) L&#61;mid&#43;1,ans&#61;tot-k*mid; else R&#61;mid-1;
39 }
40 printf("%d\n",ans);
41 return 0;
42 }

 

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



推荐阅读
  • 本题探讨如何通过最大流算法解决农场排水系统的设计问题。题目要求计算从水源点到汇合点的最大水流速率,使用经典的EK(Edmonds-Karp)和Dinic算法进行求解。 ... [详细]
  • 题目描述:给定n个半开区间[a, b),要求使用两个互不重叠的记录器,求最多可以记录多少个区间。解决方案采用贪心算法,通过排序和遍历实现最优解。 ... [详细]
  • 毕业设计:基于机器学习与深度学习的垃圾邮件(短信)分类算法实现
    本文详细介绍了如何使用机器学习和深度学习技术对垃圾邮件和短信进行分类。内容涵盖从数据集介绍、预处理、特征提取到模型训练与评估的完整流程,并提供了具体的代码示例和实验结果。 ... [详细]
  • Python自动化处理:从Word文档提取内容并生成带水印的PDF
    本文介绍如何利用Python实现从特定网站下载Word文档,去除水印并添加自定义水印,最终将文档转换为PDF格式。该方法适用于批量处理和自动化需求。 ... [详细]
  • 扫描线三巨头 hdu1928hdu 1255  hdu 1542 [POJ 1151]
    学习链接:http:blog.csdn.netlwt36articledetails48908031学习扫描线主要学习的是一种扫描的思想,后期可以求解很 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 本文深入探讨了 Java 中的 Serializable 接口,解释了其实现机制、用途及注意事项,帮助开发者更好地理解和使用序列化功能。 ... [详细]
  • 本章将深入探讨移动 UI 设计的核心原则,帮助开发者构建简洁、高效且用户友好的界面。通过学习设计规则和用户体验优化技巧,您将能够创建出既美观又实用的移动应用。 ... [详细]
  • 机器学习中的相似度度量与模型优化
    本文探讨了机器学习中常见的相似度度量方法,包括余弦相似度、欧氏距离和马氏距离,并详细介绍了如何通过选择合适的模型复杂度和正则化来提高模型的泛化能力。此外,文章还涵盖了模型评估的各种方法和指标,以及不同分类器的工作原理和应用场景。 ... [详细]
  • 本文介绍了在Windows环境下使用pydoc工具的方法,并详细解释了如何通过命令行和浏览器查看Python内置函数的文档。此外,还提供了关于raw_input和open函数的具体用法和功能说明。 ... [详细]
  • 本文详细介绍了C语言中链表的两种动态创建方法——头插法和尾插法,包括具体的实现代码和运行示例。通过这些内容,读者可以更好地理解和掌握链表的基本操作。 ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • 本文介绍如何在现有网络中部署基于Linux系统的透明防火墙(网桥模式),以实现灵活的时间段控制、流量限制等功能。通过详细的步骤和配置说明,确保内部网络的安全性和稳定性。 ... [详细]
  • 优化局域网SSH连接延迟问题的解决方案
    本文介绍了解决局域网内SSH连接到服务器时出现长时间等待问题的方法。通过调整配置和优化网络设置,可以显著缩短SSH连接的时间。 ... [详细]
  • 本题旨在通过给定的评级信息,利用拓扑排序和并查集算法来确定全球 Tetris 高手排行榜。题目要求判断是否可以根据提供的信息生成一个明确的排名表,或者是否存在冲突或信息不足的情况。 ... [详细]
author-avatar
黑衬衫1994
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有