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

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

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

二叉树:就是度为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;
}
相关推荐
手握风云-1 小时前
优选算法的寻踪契合:字符串专题
算法
闭着眼睛学算法1 小时前
【华为OD机考正在更新】2025年双机位A卷真题【完全原创题解 | 详细考点分类 | 不断更新题目 | 六种主流语言Py+Java+Cpp+C+Js+Go】
java·c语言·javascript·c++·python·算法·华为od
IT古董2 小时前
【第五章:计算机视觉-项目实战之目标检测实战】2.目标检测实战:中国交通标志检测-(2)中国交通标志检测数据格式转化与读取
算法·目标检测·计算机视觉
MobotStone2 小时前
LLM 采样入门到进阶:理解与实践 Top-K、Top-P、温度控制
算法
Coovally AI模型快速验证2 小时前
从避障到实时建图:机器学习如何让无人机更智能、更安全、更实用(附微型机载演示示例)
人工智能·深度学习·神经网络·学习·安全·机器学习·无人机
杨小码不BUG2 小时前
CSP-J/S初赛知识点精讲-图论
c++·算法·图论··编码·csp-j/s初赛
麦麦在写代码3 小时前
动态内存管理 干货2
c语言
东木君_3 小时前
RK3588:MIPI底层驱动学习——入门第三篇(IIC与V4L2如何共存?)
学习
say_fall3 小时前
C语言底层学习(2.指针与数组的关系与应用)(超详细)
c语言·开发语言·学习
祐言QAQ3 小时前
(超详细,于25年更新版) VMware 虚拟机安装以及Linux系统—CentOS 7 部署教程
linux·运维·服务器·c语言·物联网·计算机网络·centos