树形结构C语言的实现
创作时间:
作者:
@小白创作中心
树形结构C语言的实现
引用
CSDN
1.
https://blog.csdn.net/2301_81689298/article/details/140215886
树形结构是一层次的嵌套结构。一个树形结构的外层和内层有相似的结构,所以这种结构多可以递归的表示。经典数据结构中的各种树状图是一种典型的树形结构:一棵树可以简单的表示为根,左子树,右子树。左子树和右子树又有自己的子树。
一.什么是树:
树形结构是一层次的嵌套结构。一个树形结构的外层和内层有相似的结构,所以这种结构多可以递归的表示。经典数据结构中的各种树状图是一种典型的树形结构:一棵树可以简单的表示为根,左子树,右子树。左子树和右子树又有自己的子树。
树的一些属性:
- 结点(Node):表示树中的数据元素,由数据项和数据元素之间的关系组成。在图中,共有10个结点。
- 结点的度(Degree of Node):结点所拥有的子树的个数,在图中,结点A的度为3。
- 树的度(Degree of Tree):树中各结点度的最大值。在图5.1中,树的度为3。
- 叶子结点(Leaf Node):度为0的结点,也叫终端结点。在图5.1中,结点E、F、G、H、I、J都是叶子结点。
- 分支结点(Branch Node):度不为0的结点,也叫非终端结点或内部结点。在图5.1中,结点A、B、C、D是分支结点。
- 孩子(Child):结点子树的根。在图中,结点B、C、D是结点A的孩子。
- 双亲(Parent):结点的上层结点叫该结点的双亲。在图中,结点B、C、D的双亲是结点A。
- 祖先(Ancestor):从根到该结点所经分支上的所有结点。在图中,结点E的祖先是A和B。
- 子孙(Descendant):以某结点为根的子树中的任一结点。在图中,除A之外的所有结点都是A的子孙。
- 兄弟(Brother):同一双亲的孩子。在图5.1中,结点B、C、D互为兄弟。
- 结点的层次(Level of Node):从根结点到树中某结点所经路径上的分支数称为该结点的层次。根结点的层次规定为1,其余结点的层次等于其双亲结点的层次加1。 [1]
- 堂兄弟(Sibling):同一层的双亲不同的结点。在图中,G和H互为堂兄弟。
- 树的深度(Depth of Tree):树中结点的最大层次数。在图5.1中,树的深度为3。 [1]
- 无序树(Unordered Tree):树中任意一个结点的各孩子结点之间的次序构成无关紧要的树。通常树指无序树。 [1]
- 有序树(Ordered Tree):树中任意一个结点的各孩子结点有严格排列次序的树。二叉树是有序树,因为二叉树中每个孩子结点都确切定义为是该结点的左孩子结点还是右孩子结点。 [1]
- 森林(Forest):m(m≥0)棵树的集合。自然界中的树和森林的概念差别很大,但在数据结构中树和森林的概念差别很小。从定义可知,一棵树由根结点和m个子树构成,若把树的根结点删除,则树变成了包含m棵树的森林。当然,根据定义,一棵树也可以称为森林。
一些特殊的树:
树中最特殊最经典的就是二叉树,二叉树顾名思义就是只有两个分叉的树,也就是度为二的树。
二叉树中又有俩个最为经典的树分别为完全二叉树和满二叉树。
一棵深度为k且有2^k-1个结点的二叉树称为满二叉树。
如果对满二叉树的结点进行编号, 约定编号从根结点起, 自上而下, 自左而右。则深度为k的, 有n个结点的二叉树, 当且仅当其每一个结点都与深度为k的满二叉树中编号从1至n的结点一一对应时, 称之为完全二叉树。
二.用c语言实现一颗树:
要实现一颗树我们首先要先定义一个树的结构体
然后要确定我们树的基本功能
接着就是写完这些函数
#include"BinaryTree.h"
BTNode* BinaryTreeCreate(BTDataType* a, int* pi)
{
if (a[*pi] == '#')
{
(*pi)++;
return NULL;
}
BTNode* root = (BTNode*)malloc(sizeof(BTNode));
root->data = a[(*pi)++];
root->left = BinaryTreeCreate(a, pi);
root->right = BinaryTreeCreate(a, pi);
return root;
}
void BinaryTreeDestory(BTNode* root)
{
assert(root);
if (root == NULL)
return;
BinaryTreeDestory(root->right);
BinaryTreeDestory(root->left);
free(root);
root = NULL;
}
int BinaryTreeSize(BTNode* root)
{
if (root == NULL)
return 0;
return BinaryTreeSize(root->left) + BinaryTreeSize(root->right) + 1;
}
int BinaryTreeLeafSize(BTNode* root)
{
if (root == NULL)
return 0;
if (root->left == NULL && root->right == NULL)
return 1;
return BinaryTreeLeafSize(root->left) + BinaryTreeLeafSize(root->right);
}
int BinaryTreeLevelKSize(BTNode* root, int k)
{
if (root == NULL)
return 0;
if (k == 1)
return 1;
k--;
return BinaryTreeLevelKSize(root->left,k) + BinaryTreeLevelKSize(root->right,k);
}
BTNode* BinaryTreeFind(BTNode* root, BTDataType x)
{
if (root == NULL)
return NULL;
if (root->data == x)
return root;
BTNode* leftfind = BinaryTreeFind(root->left, x);
if (leftfind != NULL)
return leftfind;
BTNode* rightfind = BinaryTreeFind(root->right, x);
if (rightfind != NULL)
return rightfind;
return NULL;
}
void BinaryTreePrevOrder(BTNode* root)
{
if (root)
{
printf("%c", root->data);
BinaryTreePrevOrder(root->left);
BinaryTreePrevOrder(root->right);
}
}
void BinaryTreeInOrder(BTNode* root)
{
if (root)
{
BinaryTreeInOrder(root->left);
printf("%c", root->data);
BinaryTreeInOrder(root->right);
}
}
void BinaryTreePostOrder(BTNode* root)
{
if (root)
{
BinaryTreePostOrder(root->left);
BinaryTreePostOrder(root->right);
printf("%c", root->data);
}
}
热门推荐
马桶下水口尺寸规格全解析:从8厘米到10厘米,如何选择最合适的尺寸?
结核感染T细胞检测结果怎么看
为什么想成为一名老师?
一次搞懂!益生菌怎么挑选才正确?乳酸菌≠益生菌(2024年更新)
如何正确使用除螨剂?这种使用方式有哪些注意事项?
布艺沙发怎么洗?一文详解布艺沙发清洁保养全攻略
房屋继承收费标准及继承、买卖、赠与费用对比
人格障碍的概念:定义、分类与成因
人格障碍是什么症状
华硕官方指南:Windows蓝屏错误(蓝底白字)的全面解决方案
吃伊马替尼会口鼻干燥吗,怎么办
科技浪潮下如何培养创新人才?学者:科教融汇、产学深度结合
深层解读光速不变原理,光速为什么绝对不变?
OKR和KPI的区别——让你真正搞懂这两大管理工具
如何实施OKR系统以提升团队绩效与目标对齐?
小型电动工具大全
“如何正确安装SIM卡及注意事项”
兰花促花方法及人工催花技术要领(提高兰花开花率的关键诀窍)
什么品种兰花最受欢迎卖得最好
快克能和头孢能一起吃吗
脑室脉络膜囊肿患者治疗注意事项及效果提升指南
歌词也能用在作文中?语文作文最容易被忽视的素材
煤的种类、主产地和用途:无烟煤、焦煤、肥煤、瘦煤、弱粘结煤、气煤、长焰煤、褐煤
哪些问题适合通过工伤律师免费咨询解决?
从南京地理格局变迁感受长江的历史和文脉
物联网开发:ESP32和ESP8266的全面对比
如何创建Web快捷方式:从浏览器到移动设备的全面指南
校园智能水电预付费管理系统
先息后本 银行继续卷房贷
别再把紫米和黑米搞混了,有三种营养差异真大