树形数据结构

在这里插入图片描述
节点的高度=节点到叶子结点的最长路径(边数)
节点的深度=根节点到这个节点所经历的边的个数
节点的层数=节点的深度+1
树的高度=根节点的高度
在这里插入图片描述在这里插入图片描述
在计算机科学中,二叉树是一种“树”数据结构,树上的每个节点最多有两个孩子,分别为左孩和右孩。两颗子树分别为左子树、右子树。二叉树有5中形态。
在这里插入图片描述
如果二叉树中除了叶子结点,每个节点都有左右两个子节点,则此二叉树称为满二叉树。叶子结点全部都在最底层。
满二叉树总的节点个数为2^n−1(n为树的层数)
在这里插入图片描述
如果二叉树中除去最后一层节点为满二叉树,且最后一层的结点依次从左到右分布,则此二叉树被称为完全二叉树。
n个结点的完全二叉树的层数:[log_2⁡n ]+1
满二叉树一定是完全二叉树,但是完全二叉树不一定是完全二叉树。
二叉树的存储:
在这里插入图片描述
链式存储

struct note(){
	int data;
	int parent,lchild,rchild; 
}

在这里插入图片描述在这里插入图片描述

顺序存储用数组!!!
访问结构体中元素三种方式:
方式一:link->num

#include<cstdio>
using namespace std;
struct stu{
	int num;
	struct stu *next;
}stu,*link;
int main(){
	link = &stu;//link指针需要先赋值,存的是结构体变量的地址
	link->num = 1;
	printf("%d",link->num);
}

方式二:(*link).num

#include<cstdio>
using namespace std;
struct stu{
	int num;
	struct stu *next;
}stu,*link;
int main(){
	link = &stu;//link指针需要先赋值,存的是结构体变量的地址
	(*link).num = 1;
	printf("%d",(*link)num);
}

方式三:stu.num

#include<cstdio>
using namespace std;
struct stu{
	int num;
	struct stu *next;
}stu,*link;
int main(){
	stu.num = 1;
	printf("%d",stu.num);
}

在这里插入图片描述
遍历二叉树可以算作是对树存储结构做的最多的操作。
在这里插入图片描述
遍历一棵树,有三种方法:前序遍历、中序遍历、后序遍历,这里的序指的是父节点的遍历顺序,前序就是先遍历父节点,中序就是直接遍历父节点,后序就是最后遍历父节点。二叉树的前序、中序、后序遍历,其实是一个递归的过程。
在这里插入图片描述
先序遍历得到的序列为:1245367
在这里插入图片描述
中序遍历得到的序列为:4351637
在这里插入图片描述后序遍历得到的序列为:4526731
在这里插入图片描述
已知中序后序,求前序:
在这里插入图片描述
已知前序中序,求后序:在这里插入图片描述
已知前序后序,求中序:在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值