【题解】洛谷 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;
} 
相关推荐
灵感__idea1 小时前
Hello 算法:贪心的世界
前端·javascript·算法
澈2073 小时前
深入浅出C++滑动窗口算法:原理、实现与实战应用详解
数据结构·c++·算法
A.A呐3 小时前
【C++第二十九章】IO流
开发语言·c++
ambition202423 小时前
从暴力搜索到理论最优:一道任务调度问题的完整算法演进历程
c语言·数据结构·c++·算法·贪心算法·深度优先
cmpxr_3 小时前
【C】原码和补码以及环形坐标取模算法
c语言·开发语言·算法
qiqsevenqiqiqiqi3 小时前
前缀和差分
算法·图论
代码旅人ing3 小时前
链表算法刷题指南
数据结构·算法·链表
kebeiovo3 小时前
atomic原子操作实现无锁队列
服务器·c++
Yungoal3 小时前
常见 时间复杂度计算
c++·算法
6Hzlia4 小时前
【Hot 100 刷题计划】 LeetCode 48. 旋转图像 | C++ 矩阵变换题解
c++·leetcode·矩阵