树的基本概念,并查集复习(学习记录)

今天主要学习的是树,然后利用题目复习了一下并查集。

树的一些概念词,度,父节点(双亲节点),子节点,树的深度(高度)等等。

二叉树:就是度为2的树

学了前序,中序,后序,简单用代码实现前序(核心我觉得是构建树,在C语言的代码中,就是利用结构体来表示一棵树)

前序,中序,后序的意思也很容易理解

举前序的例子,前序其实就是先 根,再左子树,再右子树。(所以其实前序也被称为先根)

中序:左子树,根,右子树

后序;左子树,右子树,根


下面是今天并查集的复习:

代码的逻辑很清楚,题目思考的步骤也有,便于回顾和复习

P1536 村村通( 村村通 - 洛谷

cpp 复制代码
P1536 村村通
我的思路:
1. 设每条路的端点的门主都是自己
2. 改变现有路的端点的门主,统一门主
3. 查找每个端点的门主是否都是之前统一的门主,如果不是,就+1条路

一把过,稳稳的很安心!
#include<stdio.h>
int pre[100001];

int find(int x) {
	if (pre[x] == x) {
		return x;
	}
	return pre[x] = find(pre[x]);
	
}

int join(int a, int b) {
	//找到门主
	int fx = find(a);
	int fy = find(b);
	//统一门主
	pre[fx] = fy;
	
}

int main() {
	int n = 0;//城镇
	int m = 0;//道路
	
	int a, b = 0;
	scanf("%d", &n);
	while (n != 0) {
		int ans = 0;//还要修几条路
		scanf("%d", &m);
		//将每条路的门主都设为自己
		for (int i = 1; i <= n; i++) {
			pre[i] = i;
		}
		for (int i = 1; i <= m; i++) {
			scanf("%d%d", &a, &b);
			//将路的端点的门主统一
			join(a, b);
		}
		for (int i = 1; i <= n; i++) {
			if (pre[i] == i) {
				ans++;
			}
		}
		printf("%d\n", ans - 1);
		scanf("%d", &n);
	}
	return 0;
}
相关推荐
云间月131415 分钟前
飞算JavaAI智慧教育场景实践:从个性化学习到教学管理的全链路技术革新
学习·飞算javaai挑战赛
欧哈东哥15 分钟前
【C++】标准库中用于组合多个值的数据结构pair、tuple、array...
java·数据结构·c++
来自天蝎座的孙孙1 小时前
洛谷P1595讲解(加强版)+错排讲解
python·算法
GawynKing1 小时前
图论(5)最小生成树算法
算法·图论·最小生成树
试剂界的爱马仕1 小时前
胶质母细胞瘤对化疗的敏感性由磷脂酰肌醇3-激酶β选择性调控
人工智能·科技·算法·机器学习·ai写作
promising-w1 小时前
【嵌入式C语言】六
c语言·开发语言
打不了嗝 ᥬ᭄2 小时前
Linux 信号
linux·开发语言·c++·算法
ankleless2 小时前
C语言(11)—— 数组(超绝详细总结)
c语言·零基础·数组·二维数组·自学·一维数组
张子夜 iiii2 小时前
机器学习算法系列专栏:主成分分析(PCA)降维算法(初学者)
人工智能·python·算法·机器学习