树形结构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);
}
}
热门推荐
孩子晚上睡觉必须全黑环境,一点光都没有吗?
餐饮连锁扩张好不好?全面解析餐饮连锁扩张策略与风险
陆游九首经典诗词,千古流芳,首首都有千古名句
帕金森:焦虑情绪竟成了病情发展的隐形推手
陶渊明的主要文学成就
大模型(LLM)微调并不复杂,数据才是关键:3个实例详解数据准备
应对大模型幻觉挑战,如何构建高质量SFT数据?
只凭报警记录能认定家暴吗?这些证据更有效
期货成交量能说明什么?如何通过成交量分析市场趋势?
社区生鲜超市现状背景前景如何?背景分析及前景预测
林则徐生平事迹:民族英雄的辉煌篇章
她叫杨妞花
新生儿使用抗生素的危害性及预防措施
白癜风的发病机制及他卡西醇在白癜风治疗中的应用
打印机与电脑连接方式详解(了解不同的打印机和电脑连接方式)
冰心:“有了爱就有了一切”
数据结构:单链表的节点概念与代码实现
米格31有多大?与波音737和苏27同框才明白,为何是最大的战斗机
在Mac中打开终端的3种方法
陆治的画,潇洒脱俗,饶有风韵!
房改房交易土地出让金是怎么回事
三个善意取得的构成要件及其法律适用分析
保险法中法定继承人顺序是怎样的
砂糖橘上火还是降火
探索俄罗斯自然之美:贝加尔湖自然保护区
定金合同不交钱就不生效吗
FPC补强材质如何选择?
大迫杰最爱的一个训练动作!帮助跑者提升运动表现和减少受伤
【涨知识】呼吸道感染看不见的“元凶”与预防
这类租房100%踩雷!中介假房源忽悠人,4套“恰好”刚出租,实地看房贵1000多