关于二叉树(2)

二叉树的节点数量

一棵高度为 n 的二叉树,最多包括 个节点。

二叉树的存储

可以继续沿用存储树的方法,来存储二叉树。

cpp 复制代码
struct node{
    int value;
    vector<int> childs; //用来记录所有子节点的编号
}nodes[10000];

int root;
//root为根节点

也可以利用二叉树的特性,用左右子树的方式,来存储二叉树。

用结构体来表示二叉树的节点, 每个节点存储了当前节点的值, 以及左子树和右子树的编号。

cpp 复制代码
struct node{
    int value;
    int left;
    int right;
}nodes[10000];
int root;
//root为根节点

二叉树的遍历

遍历二叉树的方法可以沿用遍历树的方法------递归。

复制代码
DFS(当前节点u){
    DFS(u.left);
    DFS(u.right);
}

在此基础上,二叉树的遍历又分为以下三种:

顺序
先序遍历 根 左 右
中序遍历 左 根 右
后序遍历 左 右 根
先序遍历

遍历顺序规则为:根左右,遍历方法:

(1)访问根节点

(2)采用先序递归遍历左子树

(3)采用先序递归遍历右子树

示例代码:

cpp 复制代码
/*题目:
输入一个整数n(n <= 100000),表示二叉树中节点个数,编号为1~n。约定1号节点为二叉树的根节点。
然后输入n行,每行包括两个整数,第i行表示编号为i的节点的左子节点和右子节点的编号。
如果某个节点没有左子节点,那么对应输行的第一个整数为0;如果某个节点没有右子节点,
那么对应行的第二个整数为0。
先序遍历输出此二叉树每个节点的编号,每行输出一个编号。
先序遍历(DLR),是二叉树遍历的一种,也叫做先根遍历、前序遍历、前序周游,可记做根左右。
前序遍历首先访问根节点然后遍历左子树,最后遍历右子树。
*/
#include<bits/stdc++.h>
using namespace std;
int n;
struct link{
	int left;
	int right;
}a[100005];
void dfs(int x){
	if(x==0) return ;
	cout<<x<<endl;
	dfs(a[x].left);
	dfs(a[x].right);
}
int main(){
	cin>>n;
	for(int i=1;i<=n;i++){
		int x,y;
		cin>>x>>y;
		a[i].left=x;
		a[i].right=y;
	}
	dfs(1);
	return 0;
}
中序遍历

遍历顺序规则为:左根右,遍历方法:

(1)采用中序遍历左子树

(2)访问根节点

(3)采用中序遍历右子树

示例代码:

cpp 复制代码
/*题目:
输入一个整数n(n <= 100000),表示二叉树中节点个数,编号为1~n。约定1号节点为二叉树的根节点。
然后输入n行,每行包括两个整数,第i行表示编号为i的节点的左子节点和右子节点的编号。
如果某个节点没有左子节点,那么对应输行的第一个整数为0;如果某个节点没有右子节点,
那么对应行的第二个整数为0。
中序遍历输出此二叉树每个节点的编号,每行输出一个编号。
*/
#include<bits/stdc++.h>
using namespace std;
int n;
struct link{
	int left,right;
}a[100005];
void dfs(int x){
	if(x==0) return ;
	dfs(a[x].left);
	cout<<x<<endl;
	dfs(a[x].right);
} 
int main(){
	cin>>n;
	for(int i=1;i<=n;i++){
		int x,y;
		cin>>x>>y;
		a[i].left=x;
		a[i].right=y;
	} 
	dfs(1);
	return 0;
}

后序遍历

遍历顺序规则为:左右根,遍历方法:

(1)采用后序递归遍历左子树

(2)采用后序递归遍历右子树

(3)访问根节点

示例代码:

cpp 复制代码
/*题目:
输入一个整数n(n <= 100000),表示二叉树中节点个数,编号为1~n。
约定1号节点为二叉树的根节点。然后输入n行,每行包括两个整数,
第i行表示编号为i的节点的左子节点和右子节点的编号。
如果某个节点没有左子节点,那么对应输行的第一个整数为0;如果某个节点没有右子节点,
那么对应行的第二个整数为0。 后序遍历输出此二叉树每个节点的编号,每行输出一个编号。
*/
#include<bits/stdc++.h>
using namespace std;
int n;
struct link{
	int left,right;
}a[100005];
void dfs(int x){
	if(x==0) return ;
	dfs(a[x].left);
	dfs(a[x].right);
	cout<<x<<endl;
}
int main(){
	cin>>n;
	for(int i=1;i<=n;i++){
		int x,y;
		cin>>x>>y;
		a[i].left=x;
		a[i].right=y;
	} 
	dfs(1);
	return 0;
} 
相关推荐
unicrom_深圳市由你创科技6 小时前
哪些控制逻辑应该放在 PLC,哪些放在上位机?
c++
玖玥拾7 小时前
C/C++ 基础笔记(十三)继承
c语言·c++·继承
ao-weilai8 小时前
C++:哈希表
c++·哈希算法·散列表
汉克老师9 小时前
GESP7级C++考试语法知识(二、指数函数(1、pow() 函数)
c++·指数函数·pow·gesp7级·精度误差
退休倒计时9 小时前
【每日一题】LeetCode 53. 最大子数组和 TypeScript
数据结构·算法·leetcode·typescript
旖-旎9 小时前
FloodFill(图像渲染)(1)
c++·算法·深度优先·力扣
2601_961875249 小时前
法考资料2026|全套|资料已整理
数据结构·算法·链表·贪心算法·eclipse·线性回归·动态规划
汉克老师10 小时前
GESP2026年3月认证C++六级真题与解析(编程题1 选数)
c++·动态规划·线性dp·gesp六级·状态转移·选与不选
有点。10 小时前
C++倍增法(练习题)
c++·算法
凡人叶枫10 小时前
Effective C++ 条款23:宁以 non-member、non-friend 替换 member 函数
linux·开发语言·c++·嵌入式开发