【数据结构】计算节点个数和二叉树高度(C语言版)

数据结构——计算节点个数、二叉树高度
  • 一、计算各种节点
    • (1)计算总节点:
    • (2)计算单分支节点:
    • (3)计算双分支节点:
  • 二、计算二叉树高度
    • 代码实现:

一、计算各种节点

二叉树结构体如下:

//	二叉树结构体 
typedef struct TreeLink{int Data;struct TreeLink *LChild;struct TreeLink *RChild;
}T_LINK,*TLINK;	

(1)计算总节点:

让根节点指针开始,进行二叉树的遍历,遍历树节点中不为NULL下,及存在节点,遍历次数相加之和 + 根节点 及为总节点

//	计算二叉树总节点
int Calc_AllJieDian(TLINK p)
{if(p == NULL)	//	二叉树为空树 或者 该节点下没有子树{return 0;}return 1+Calc_AllJieDian(p->LChild)+Calc_AllJieDian(p->RChild); //	遍历该节点的左右子树,再加上根节点 
} 

(2)计算单分支节点:

遍历二叉树途中,只记录遍历树节点中遇到(左边子树存在,右边子树为NULL )或者 (右边子树存在,左边子树为NULL)这种节点,才让递归 返回值 +1,依次累加

//	计算单分支节点 
int Signal_Node(TLINK p)
{if(p==NULL){return 0;//	当前节点左右子树其中一个为NULL,单支点数+1 }else if((p->LChild==NULL&&p->RChild!=NULL)||(p->LChild!=NULL&&p->RChild==NULL)){return Signal_Node(p->LChild)+Signal_Node(p->RChild)+1;}else{//	双分支都存在,继续向下遍历 return Signal_Node(p->LChild)+Signal_Node(p->RChild);}
} 

(3)计算双分支节点:

计算双分支节点思路 和 计算单支点相反 为: 遍历 二叉树 只记录 节点指针指向的节点中 左右子树都存在 的时候,递归返回值+1,累加最后返回 就是双分支节点的个数

//	计算双分支节点
int Calc_DoubleNode(TLINK p)
{	if(p==NULL){return 0;}else if(p->LChild!=NULL&&p->RChild!=NULL){	//	当节点左右子树都存在时,双分支数+1return Calc_DoubleNode(p->LChild)+Calc_DoubleNode(p->RChild)+1;	//	继续遍历左右子树 }else{	//	否则只继续向下遍历左右子树 return Calc_DoubleNode(p->LChild)+Calc_DoubleNode(p->RChild);}			
} 

总代码:

#include<stdio.h>
#include<stdlib.h>//	二叉树结构体 
typedef struct TreeLink{int Data;struct TreeLink *LChild;struct TreeLink *RChild;
}T_LINK,*TLINK;	//	创建二叉树 
TLINK Create_TreeLink()
{TLINK T;int data;int temp;scanf("%d",&data);temp = getchar();	//	吸收scanf带来的回车 if(data == -1){		//	输入-1表示该节点下左树或者右树下不存数据,返回到上一级节点 return NULL;		}else{T = (TLINK)malloc(sizeof(T_LINK));	//	每个节点开辟空间 T->Data = data;printf("请输入%d节点下左节点数据:  ",data);T->LChild = Create_TreeLink();printf("请输入%d节点下右节点数据:  ",data);T->RChild = Create_TreeLink();return T;}	
}//	计算二叉树总节点
int Calc_AllJieDian(TLINK p)
{if(p == NULL){return 0;}return 1+Calc_AllJieDian(p->LChild)+Calc_AllJieDian(p->RChild); //	遍历该节点的左右子树,再加上根节点 
} //	计算双分支节点
int Calc_DoubleNode(TLINK p)
{	if(p==NULL){return 0;}else if(p->LChild!=NULL&&p->RChild!=NULL){	//	当节点左右子树都存在时,双分支数+1return Calc_DoubleNode(p->LChild)+Calc_DoubleNode(p->RChild)+1;	//	继续遍历左右子树 }else{	//	否则只继续向下遍历左右子树 return Calc_DoubleNode(p->LChild)+Calc_DoubleNode(p->RChild);	}			
} //	计算单分支节点 
int Signal_Node(TLINK p)
{if(p==NULL){return 0;//	当前节点左右子树其中一个为NULL,单支点数+1 }else if((p->LChild==NULL&&p->RChild!=NULL)||(p->LChild!=NULL&&p->RChild==NULL)){return Signal_Node(p->LChild)+Signal_Node(p->RChild)+1;}else{//	双分支都存在,继续向下遍历 return Signal_Node(p->LChild)+Signal_Node(p->RChild);}
} int main()
{TLINK T;				//	创建二叉树指针 printf("输入第一个节点:\n");T = Create_TreeLink();int count = Calc_AllJieDian(T);int SignalNode = Signal_Node(T); int DoubleNode = Calc_DoubleNode(T);printf("总节点个数为: %d\n",count); printf("叶子节点个数为: %d\n",count-1);printf("单支节点个数为: %d\n",SignalNode);printf("双支节点个数为: %d\n",DoubleNode); 
}

运行结果:
在这里插入图片描述

二、计算二叉树高度

思路 :

递归遍历二叉树,除去根节点下,比较节点左右子树的遍历次数大小,最后大的结果 加上 根节点 1 ,就是二叉树的高度

代码实现:

//	计算二叉树的高度
int Calc_Hight(TLINK p)
{int left ;			//	计算左子树 节点 int right; 			//	计算右子树节点int Max; if(p != NULL){left = Calc_Hight(p->LChild);	//	遍历该节点的左子树right= Calc_Hight(p->RChild);	//	遍历该节点的右子树Max = left>right?left:right; 	//	比较左右子树的高度return Max+1; }else{return 0;}
}
            </div>

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

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

相关文章

NSSCTF Round#18 RE GenshinWishSimulator WP

恶搞原神抽卡模拟器 看到软件的界面&#xff0c;大致有三种思路&#xff1a; 修改石头数量一直抽&#xff0c;如果概率正常肯定能抽到&#xff08;但是估计设置的概率是0&#xff09;在源码里找flag的数据把抽卡概率改成100%直接抽出来 Unity逆向&#xff0c;根据经验应该dnsp…

MySQL数据库⑩_视图+MySQL用户管理(增删查改)

目录 1. 视图的概念和规则限制 2. 视图的基本使用 2.1 创建视图 2.2 修改视图影响基表 2.3 修改基表影响视图 2.4 删除视图 3. MySQL用户管理 3.1 用户信息 3.2 创建用户 3.3 修改用户密码 3.4 删除用户 4. 用户权限 4.1 MySQL权限 4.2 给用户授权 4.3 回收权限…

Vue-自定义属性和插槽(五)

目录 自定义指令 基本语法 (全局&局部注册) 指令的值 练习&#xff1a;v-loading 指令封装 总结&#xff1a; 插槽&#xff08;slot&#xff09; 默认插槽 插槽 - 后备内容&#xff08;默认值&#xff09; 具名插槽 具名插槽基本语法: 具名插槽简化语法: 作…

单片机学习路线(简单介绍)

学习单片机对于电子爱好者和未来的嵌入式系统工程师来说是一段激动人心的旅程。单片机因其强大的功能、灵活性以及在各种智能设备中的广泛应用&#xff0c;成为了电子和计算机科学领域一个不可或缺的组成部分。如果你对如何开始这段旅程感到好奇&#xff0c;那么你来对地方了。…

SpringIOC之support模块ReloadableResourceBundleMessageSource

博主介绍&#xff1a;✌全网粉丝5W&#xff0c;全栈开发工程师&#xff0c;从事多年软件开发&#xff0c;在大厂呆过。持有软件中级、六级等证书。可提供微服务项目搭建与毕业项目实战&#xff0c;博主也曾写过优秀论文&#xff0c;查重率极低&#xff0c;在这方面有丰富的经验…

【MySQL】待修改

外键约束 含义 外键&#xff1a;用来让两张表的数据之间建立连接&#xff0c;从而保证数据的完整性和一致性。 员工表emp&#xff08;子表&#xff09; idnameagejobsalaryentrydatemanageriddept_id1金庸66总裁200002000-01-01null52张无忌20项目经理125002005-12-05113杨…

【安装指南】图床神器之Picgo下载、安装详细教程

&#x1f33c;一、概述 PicGo是一款开源的图片上传、管理工具&#xff0c;旨在帮助用户快速上传图片到云存储或图床&#xff0c;并提供链接方便在网页或其他应用中使用。它支持各种常见的图床服务商&#xff0c;如GitHub、七牛云、腾讯云等&#xff0c;并提供了简洁易用的界面和…

python3 中try 异常调试 raise 异常抛出

一、什么是异常&#xff1f; 异常即是一个事件&#xff0c;该事件会在程序执行过程中发生&#xff0c;影响了程序的正常执行。 一般情况下&#xff0c;在Python无法正常处理程序时就会发生一个异常。 异常是Python对象&#xff0c;表示一个错误。 当Python脚本发生异常时我…

四、OpenAI之文本生成模型(Text Generation)

文本生成模型 OpenAI的文本生成模型(也叫做生成预训练的转换器(Generative pre-trained transformers)或大语言模型)已经被训练成可以理解自然语言、代码和图片的模型。模型提供文本的输出作为输入的响应。对这些模型的输入内容也被称作“提示词”。设计提示词的本质是你如何对…

响应式编程四Spring WebFlux高阶实战,2W字干货!!

响应式编程四Spring WebFlux高阶实战 WebFlux作为核心响应式服务器基础响应式Web内核响应式Web和MVC框架基于WebFlux的纯函数式Web基于WebClient的非阻塞跨服务通讯Spring Web Flux 和Spring Web MVC对比 WebFlux的应用基于微服务的系统 大文件上传Spring WebFlux数据库访问集成…

不要告诉我爸妈!三省吾身!保持健康的习惯——“早”读

三省吾身了? 引言代码第一篇 人民日报 不要告诉我爸妈第二篇 人民日报 【夜读】新的一年&#xff0c;保持健康的5个好习惯第三篇&#xff08;跳&#xff09; 人民日报 来啦 新闻早班车要闻社会政策 结尾 引言 我想我需要给我的文章再来点规范性的东西 让大家能够更好地阅读 比…

【项目管理】CMMI-项目结项管理过程

结项管理&#xff08;Project Closing Management, PCM&#xff09;的目的是在项目工作结束后&#xff0c;对项目工作情况、经验教训进行总结&#xff1b;依据项目的目标和计划对项目完成情况和目标实现情况进行综合评价&#xff1b;以及项目结项后的维护移交工作&#xff0c;保…