二叉树入门

这篇博客通过手动创建的一个简单二叉树,实现二叉树遍历,返回节点,叶子个数,查找结点等相关操作。

1. 二叉树的概念
二叉树不为空时,由根节点,左/右子树组成,逻辑结构如下,当二叉树为空时称为空树。
我们可以看到,左子树同样可以看作是根节点和左右子树构成,因此二叉树的基本操作需要利用递归的方式得以实现。此处需要注意的是,每次递归返回值不一定是传递给最外层的。
2.二叉树的遍历 
二叉树的遍历按照规则分为三种情况,分别是前序遍历中序遍历以及后序遍历。前序遍历先访问根节点再访问左右子树,中序遍历先访问左子树,再访问根节点和右子树,后序遍历先访问左右子树最后访问根节点。因此根据上述二叉树的排列不难写出二叉树的三种遍历情况,我们将NULL简写成 N,如下图所示:

在代码实现的过程中,我们先创建节点,在更改节点的指向,即可实现我们需要的上述的结构:
typedef int BTDataType;typedef struct BinaryTreeNode
{BTDataType data;struct BinaryTreeNode* left;struct BinaryTreeNode* right;
}BTNode;BTNode* BuyNode(BTDataType x)
{BTNode* newnode = (BTNode*)malloc(sizeof(BTNode));if (newnode == NULL){perror("malloc fail");return;}newnode->left = NULL;//初始化newnode->right = NULL;newnode->data = x;return newnode;
}BTNode* creatBinaryTree()
{BTNode* node1 = BuyNode(1);BTNode* node2 = BuyNode(2);BTNode* node3 = BuyNode(3);BTNode* node4 = BuyNode(4);BTNode* node5 = BuyNode(5);BTNode* node6 = BuyNode(6);node1->left = node2;node1->right = node4;node2->left = node3;node4->left = node5;node4->right = node6;return node1;
}
实现三种情况的遍历,我们可以通过递归实现,因为二插树可以分成根节点和左右子树,左右子树又可以分为根节点和下一个左右子树,直到叶节点。代码如下:
void preorder(BTNode* root) //前序遍历
{if (root == NULL) {printf("N ");return;}printf("%d ",root->data);preorder(root->left);preorder(root->right);
}
void Inorder(BTNode* root)//中序遍历
{if (root == NULL){printf("N ");return;}Inorder(root->left);printf("%d ", root->data);Inorder(root->right);
}
void postorder(BTNode* root)//后续遍历
{if (root == NULL){printf("N ");return;}postorder(root->left);postorder(root->right);printf("%d ", root->data);
}
3.二叉树结点的个数
求二叉树结点的个数,也是同样的道理,计算左右子树结点之和+1即可。 
int BTreeSize(BTNode* root)//分治求节点的个数
{if (root == NULL){return 0;}return BTreeSize(root->left)+ BTreeSize(root->right) + 1;
}
4.求叶子节点的个数
叶子节点的左右子树均为空,按照这个结束条件设计递归即可。
int BTreeLeafSize(BTNode* root)//求叶子节点的个数
{if (root == NULL){return 0;}if (root->left == NULL && root->right == NULL){return 1;}return BTreeLeafSize(root->left) + BTreeLeafSize(root->right) ;
}
 5. 二叉树的最长路径
将求最长路径问题分成求左右子树的最长路径,之后取大的值即可。
int BTreeHeight(BTNode* root)//最长的路径
{if (root == NULL)//一定要判空树{return 0;}int leftHeight = BTreeHeight(root->left);int rightHeight = BTreeHeight(root->right);return leftHeight > rightHeight ? leftHeight + 1 : rightHeight + 1;	
}
6. k层二叉树的节点个数 
 k层二叉树的节点个数问题可转化成左右节点k-1层节点个数之和,递归的结束条件是k == 1且节点不为空,以及节点为空。
int BTreeLevelKsize(BTNode* root,int k)//子问题,结束条件
{assert(k>0);if (root == NULL){return 0;}if (k == 1){return 1;}return BTreeLevelKsize(root->left, k - 1) + BTreeLevelKsize(root->right, k - 1);}
 7. 查找值并返回节点的地址
依然是递归调用,分为左右节点。
BTreeFind(BTNode* root, BTDataType x) 
{if (root == NULL){return NULL;}if (root->data == x){return root;}BTNode* ret1 = BTreeFind(root->left, x);	if (ret1){return ret1;}BTNode* ret2 = BTreeFind(root->right, x);	if (ret2){return ret2;}return NULL;
}
8. 结果
int main()
{BTNode* root =creatBinaryTree();preorder(root);printf("\n");Inorder(root);printf("\n");postorder(root);printf("\n");printf("BTreeSize = %d\n", BTreeSize(root));printf("BTreeLeafSize = %d\n", BTreeLeafSize(root));printf("BTreeHeight = %d\n", BTreeHeight(root));printf("BTreeLevelKsize = %d\n", BTreeLevelKsize(root,3));printf("BTreeLevelKsize = %d\n", BTreeLevelKsize(root, 2));return 0;
}


 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/522906.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

智慧农业5G融合方案(2)

应用场景 农业航空 农业农村部资料显示,植保无人机具有机动灵活、喷施效率高、施药效果好等特点,能够克服复杂地形条件下地面喷雾机具进地难的问题。目前我国有400多家企业从事植保无人机研发、生产、销售等全产业链业务。主要机型以电动多旋翼为主。2018年作业面积约2.67亿…

sign加密方法生成

1. 引入包的问题 2. 原因 .pycrypto、pycrytodome和crypto是一个东西,crypto在python上面的名字是pycrypto,它是一个第三方库,但是已经停止更新 3. 解决方法 --直接安装:pip install pycryptodome 3.但是,在使用的时…

日韩媒体宣传案例分析:CloudNEO 为您提供海外媒体宣传最佳途径

近年来,随着互联网的迅速发展和全球化的加速推进,海外市场对于企业的重要性日益凸显。尤其是在亚洲地区,日本和韩国作为亚洲最具活力和潜力的市场之一,成为众多企业争相开拓的目标。在这个过程中,媒体宣传不仅是企业推…

教你如何在公众号商城与小程序商城间做出明智之选

随着数字化时代的快速发展,微信公众号和小程序商城这两种电商解决方案各自展现了不同的魅力和挑战。对于计划自主搭建电商平台的用户而言,如何在这两者间作出明智的抉择,无疑是一个值得深思的问题。本文旨在剖析公众号商城和小程序商城的优劣…

Docker上部署LPG(loki+promtail+grafana)踩坑复盘

Docker上部署LPG(lokipromtailgrafana)踩坑复盘 声明网上配置部署踩坑 声明 参考掘金文章:https://juejin.cn/post/7008424451704356872 版本高的用docker compose命令,版本低的用docker-compose 按照文章描述,主要准备…

httprunner参数化

1. 示例 引入对应的Parameters 1.1. CSV参数 from httprunner import HttpRunner, Config, Step, RunRequest, Parameters pytest.mark.parametrize("param", Parameters({"mobile_phone-pwd": "${P(csv_data/mobile_phone-pwd.csv)}"}))def …

线性代数笔记14--投影

1. 一维空间投影 p X A e B − p B − X A A ⊤ e 0 A ⊤ ( B − X A ) 0 X A ⊤ A A ⊤ B X A ⊤ B A ⊤ A p X A A A ⊤ B A ⊤ A pXA\\ eB-pB-XA\\ A^{\top}e0\\ A^{\top}(B-XA)0\\ XA^{\top}AA^{\top}B\\ X\frac{A^{\top}B}{A^{\top}A}\\ pXAA\frac{A^{\top}B}{A^…

18个惊艳的可视化大屏(第23辑):电子政务,一目了然如胸。

hello,我是贝格前端工场老司机,这是第23期了,本次带来可视化大屏在电子政务领域的应应用案例,喜欢文章的别忘点赞关注,文章底部也有其他行业的案例。 数据展示与监控: 可视化大屏可以将政务数据以图表、地…

【校园安全】支小蜜防校园霸凌语音识别系统的好处

在校园安全领域,防校园霸凌语音识别系统的出现,为预防和应对校园霸凌行为提供了新的技术手段。本文将探讨防校园霸凌语音识别系统的好处,并分析其在校园安全建设中的重要作用。 通过安装在校园各个角落的语音识别设备,系统能够捕…

新品发布会注意事项有哪些?如何邀约媒体到场发布

传媒如春雨,润物细无声,大家好,我是51媒体网胡老师。 新品发布会的注意事项以及邀约媒体到场发布的方法如下: 一、新品发布会注意事项: 明确活动目的和主题:确定新品发布会要传达的信息和目标,…

UVA378 Intersecting Lines 题解

UVA378 Intersecting Lines 题解 怎么这么多点斜式邪教啊。 解法 在计算几何中,我们应该尽可能地避免使用浮点数的计算,尽可能地使用向量计算。 本篇题解默认读者具有向量基础。 为了方便讲解,我们将输入的四个点分别记作 A , B , C , …

md5绕过

文章目录 \\和\\\md5数组绕过科学计数法绕过双md加密md5碰撞Hash长度攻击 下面会以同一道题给大家演示: (题目来源与nssctf) 和 在php代码中我们会看到和,虽然两个都是表示相等,但是在细节上会有所部区别 :是弱比较,只…