c/c++ c语言树

本文介绍了树形数据结构的基本概念,包括树的定义、节点之间的关系及存储方式,并详细讲解了树的遍历方法,最后探讨了如何通过动态数组来改进孩子节点的存储。

1: 树是一种组织数据的方式:
1> 文件浏览器里面的文件组织方式: 文件夹,文件,文件夹中还有文件夹;
2: 树的模型:

这里写图片描述

3: A是这个树的发源地,所以叫做这个树的根节点;
B(E+F)也是一颗树,这个叫做这可树的子树;
E, F是在B下的,所以E,F是B的子节点,B是E/F的父亲节点, E/F是兄弟节点


树的设计

1: 节点数据结构

这里写图片描述

2: 树的节点:
struct tree_node {
struct tree_node* parent; // 指向自己的父亲;
struct tree_node* brother; // 指向自己的下一个兄弟
struct tree_node* children; // 指向自己的孩子,链表头;
};

这里写图片描述

这里写图片描述


树的构建

建立节点树的父子关系

这里写图片描述

这里写图片描述

这里写图片描述

遍历根节点孩子地址开辟出下一个兄弟地址,把新节点地址存放到遍历后孩子指针地址

这里写图片描述


1: 插入子节点;

这里写图片描述
2: 从树中移除子节点;

这里写图片描述

这里写图片描述

这里写图片描述


树的遍历

1: 先遍历孩子,再遍历父亲; (后序遍历)

这里写图片描述

这里写图片描述

2: 先遍历父亲,再遍历孩子; (先序遍历)
这里写图片描述

这里写图片描述


总结

1: 理解树的存储方式;
2: 理解树的遍历;
3: 使用动态数组的方式来代替链表保存孩子节点信息;


源代码–>

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值