【题解】洛谷 P2330 [SCOI2005] 繁忙的都市 [生成树]

P2330 [SCOI2005] 繁忙的都市 - 洛谷 (luogu.com.cn)

做几天题终于给我做到保底了。


题意误导人,什么改造的道路尽量少,要联通不就是生成树吗,就只能是 n - 1 条边。

然后这就是最小生成树板题,不会看这里

虽然最小生成树求的是边权和最小,但贪心算法可以保证最大边权也最小。

毕竟是先排序再从小到大选,选到联通就停手。

(题解还二分,不要看到 "最小最大" / "最大最小" 就二分!有些性质可以通过贪心顺便搞的)

代码:

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;

const int N = 8010;

struct edge {
	int x, y, c;
} a[N];

bool cmp(edge na, edge nb) {
	return na.c < nb.c;
}

int fa[310];
int findfa(int x) {
	if (fa[x] == x) {
		return fa[x];
	}
	return fa[x] = findfa(fa[x]);
}

int main () {
	ios::sync_with_stdio(false);
	cin.tie(0);
	
	int n, m;
	cin >> n >> m;
	for (int i = 1; i <= n; i ++) {
		fa[i] = i;
	}
	for (int i = 1; i <= m; i ++) {
		cin >> a[i].x >> a[i].y >> a[i].c;
	}
	sort(a + 1, a + m + 1, cmp);
	
	int sum = 0;
	for (int i = 1; i <= m; i ++) {
		int tx = findfa(a[i].x), ty = findfa(a[i].y);
		if (tx != ty) {
			sum ++;
			fa[tx] = ty;
		}
		if (sum == n - 1) {
			cout << n - 1 << " " << a[i].c << "\n";
			break;
		}
	}
	
	return 0;
} 
相关推荐
.简.简.单.单.13 小时前
Design Patterns In Modern C++ 中文版翻译 第十章 外观模式
c++·设计模式·外观模式
core51213 小时前
CatBoost:自带“翻译官”的算法专家
算法·boost·catboost
YGGP13 小时前
【Golang】LeetCode 139. 单词拆分
算法·leetcode
wuguan_13 小时前
C#递推算法
算法·c#·递推算法
十五年专注C++开发13 小时前
Jieba库: 一个中文分词领域的经典库
c++·分布式·自然语言处理·中文分词
_OP_CHEN13 小时前
【C++数据结构进阶】从 Redis 底层到手写实现!跳表(Skiplist)全解析:手把手带你吃透 O (logN) 查找的神级结构!
数据结构·数据库·c++·redis·面试·力扣·跳表
多米Domi01113 小时前
0x3f第14天 最长公共子序列
算法·深度优先
spssau13 小时前
正交试验设计全解析:从正交表生成到极差与方差分析
数据库·算法·机器学习
菜菜的院子13 小时前
vcpkg配置
c++
minhuan14 小时前
大模型应用:不减性能只减负担:大模型稀疏化技术全景与实践.36
大数据·人工智能·算法