算法训练营|图论第7天 prim算法 kruskal算法

题目:prim算法

题目链接:

53. 寻宝(第七期模拟笔试) (kamacoder.com)

代码:

cpp 复制代码
#include<bits/stdc++.h>
#include<unordered_map>
#include<unordered_set>
using namespace std;
int main() {
	int v, e;
	int x, y, k;
	cin >> v >> e;
	vector<vector<int>>grid(v + 1, vector<int>(v + 1, 10001));
	while (e--) {
		cin >> x >> y >> k;
		grid[x][y] = k;
		grid[y][x] = k;
	}
	vector<int>minEdges(v + 1, 10001);
	vector<bool>Intree(v + 1, false);
	for (int i = 1; i < v; i++) {
		int cur = -1;
		int MinVal = INT_MAX;
		for (int j = 1; j <= v; j++) {
			if (!Intree[j] && minEdges[j] < MinVal) {
				cur = j;
				MinVal = minEdges[j];
			}
		}
		Intree[cur] = true;
		for (int j = 1; j <= v; j++) {
			if (!Intree[j] && grid[cur][j] < minEdges[j]) {
				minEdges[j] = grid[cur][j];
			}
		}
	}
	int result = 0;
	for (int i = 2; i <= v; i++) {
		result += minEdges[i];
	}
	cout << result << endl;
}

题目:kruskal算法

题目链接:

53. 寻宝(第七期模拟笔试) (kamacoder.com)

代码:

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

struct Edge {
	int l, r, val;
};
int n = 10001;
vector<int>father(n, -1);
void init() {
	for (int i = 0; i < n; i++) {
		father[i] = i;
	}
}
int find(int u) {
	if (u == father[u]) return u;
	else {
		return father[u] = find(father[u]);
	}
}
void join(int u, int v) {
	u = find(u);
	v = find(v);
	if (u == v) return;
	father[v] = u;

}
static bool cmp(const Edge& a, const Edge& b) {
	return a.val < b.val;
}

int main() {
	int v, e;
	int x, y, k;
	cin >> v >> e;
	vector<Edge>edges;
	while (e--) {
		cin >> x >> y >> k;
		edges.push_back({ x,y,k });
	}
	sort(edges.begin(), edges.end(), cmp);
	vector<Edge>result;
	init();
	int result_val = 0;
	for (Edge edge : edges) {
		int x = find(edge.l);
		int y = find(edge.r);
		if (x != y) {
			result.push_back(edge);
			result_val += edge.val;
			join(x, y);
		}
	}
	
	cout << result_val << endl;
}
相关推荐
小白程序员成长日记27 分钟前
2025.11.21 力扣每日一题
算法·leetcode·职场和发展
小年糕是糕手1 小时前
【C++】C++入门 -- inline、nullptr
linux·开发语言·jvm·数据结构·c++·算法·排序算法
高洁011 小时前
具身智能-普通LLM智能体与具身智能:从语言理解到自主行动
人工智能·深度学习·算法·aigc·知识图谱
星期天22 小时前
3.2联合体和枚举enum,还有动态内存malloc,free,calloc,realloc
c语言·开发语言·算法·联合体·动态内存·初学者入门·枚举enum
Andy2 小时前
回文子串数目--动态规划算法
算法·动态规划
sin_hielo2 小时前
leetcode 1930
算法·leetcode
塞北山巅2 小时前
相机自动曝光(AE)核心算法——从参数调节到亮度标定
数码相机·算法
聆风吟º2 小时前
【数据结构入门手札】算法核心概念与复杂度入门
数据结构·算法·复杂度·算法的特性·算法设计要求·事后统计方法·事前分析估算方法
vir023 小时前
密码脱落(最长回文子序列)
数据结构·c++·算法
福尔摩斯张3 小时前
二维数组详解:定义、初始化与实战
linux·开发语言·数据结构·c++·算法·排序算法