算法训练营|图论第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;
}
相关推荐
fail_to_code25 分钟前
递归法的递归函数何时需要返回值
算法
C137的本贾尼36 分钟前
(每日一道算法题)二叉树剪枝
算法·机器学习·剪枝
吴声子夜歌1 小时前
OpenCV——Mat类及常用数据结构
数据结构·opencv·webpack
笑口常开xpr2 小时前
数 据 结 构 进 阶:哨 兵 位 的 头 结 点 如 何 简 化 链 表 操 作
数据结构·链表·哨兵位的头节点
BUG收容所所长2 小时前
栈的奇妙世界:从冰棒到算法的华丽转身
前端·javascript·算法
XRZaaa2 小时前
常见排序算法详解与C语言实现
c语言·算法·排序算法
@我漫长的孤独流浪2 小时前
数据结构测试模拟题(4)
数据结构·c++·算法
智驱力人工智能2 小时前
智慧零售管理中的客流统计与属性分析
人工智能·算法·边缘计算·零售·智慧零售·聚众识别·人员计数
WindSearcher4 小时前
大模型微调相关知识
后端·算法
取酒鱼食--【余九】4 小时前
rl_sar实现sim2real的整体思路
人工智能·笔记·算法·rl_sar