求二叉树中结点个数代码java_求二叉树中第K层结点的个数

一,问题描述

构建一棵二叉树(不一定是二叉查找树),求出该二叉树中第K层中的结点个数(根结点为第0层)

二,二叉树的构建

定义一个BinaryTree类来表示二叉树,二叉树BinaryTree 又是由各个结点组成的,因此需要定义一个结点类BinaryNode,BinaryNode作为BinaryTree的内部类。

此外,在BinaryTree中需要一定一个BinaryNode属性来表示树的根结点。

public class BinaryTree> {

private static class BinaryNode{

T element;

BinaryNode left;

BinaryNode right;

public BinaryNode(T element) {

this.element = element;

left = right = null;

}

public BinaryNode(T element, BinaryNode left, BinaryNode right){

this.element = element;

this.left = left;

this.right = right;

}

}

private BinaryNode root;

//other code.....

第一行是二叉树类的定义,第三行是结点类的定义,第20行是二叉树根的定义。

三,求解第K层结点个数的算法实现

求第K层结点的个数也可以用递归来实现:

①若二叉树为空或者K小于0,返回0

②若K等于0,第0层就是树根,根只有一个,返回1

③若K大于0,返回左子树中第K-1层结点个数 加上 右子树中第K-1层结点的个数

因为,第K层结点,相对于根的左子树 和 右子树 而言,就是第K-1层结点

其实,这是有改进的地方:对于K<0的情形,准确地说:它只是一个非法输入,而不是递归的结束条件(基准条件)。可以看出,①不要把非法输入与递归的基准条件混淆,②把非法输入的判断放到递归中判断的开销是很大的。因为每进行一次递归就需要进行一次非法输入判断。而如果在开始就把非法输入过滤掉,在递归过程中就不会存在每一次递归就判断一次非法输入了。

递归的基准条件只有两个:

1) k==0 当递归到K==0时,说明:第K层是有结点的

2) root==null 当递归到root==null时,说明:第K层没有结点

因此,可以进一步将代码改进如下:这样,不需要在每次递归的过程中还可能附加一次 k<0 的判断

/**

*

* @param k

* @return 二叉树中第K层结点的个数(根位于第0层)

*/

public int k_nodes(int k){

if(k < 0)

return 0;

return k_nodes(root, k);

}

private int k_nodes(BinaryNode root, int k){

if(root == null)

return 0;

if(k == 0)

return 1;//根结点

else

return k_nodes(root.left, k-1) + k_nodes(root.right, k-1);

}

可参考:按层打印二叉树–每行打印一层 来测试每一层是否有正确的结点个数。

四,代码实现

public class BinaryTree> {

private static class BinaryNode{

T element;

BinaryNode left;

BinaryNode right;

public BinaryNode(T element) {

this.element = element;

left = right = null;

}

}

private BinaryNode root;

/**

* 向二叉树中插入一个元素

* @param element

*/

public void insert(T element){

root = insert(root, element);

}

private BinaryNode insert(BinaryNode root, T element){

if(root == null)

return new BinaryNode(element);

int r = (int)(2*Math.random());

//随机地将元素插入到左子树 或者 右子树中

if(r==0)

root.left = insert(root.left, element);

else

root.right = insert(root.right, element);

return root;

}

/**

*

* @param k

* @return 二叉树中第K层结点的个数(根位于第0层)

*/

public int k_nodes(int k){

return k_nodes(root, k);

}

private int k_nodes(BinaryNode root, int k){

if(root == null || k < 0)

return 0;

if(k == 0)

return 1;//根结点

else

return k_nodes(root.left, k-1) + k_nodes(root.right, k-1);

}

public static void main(String[] args) {

BinaryTree tree = new BinaryTree<>();

int[] ele = C2_2_8.algorithm1(4);//构造一个随机数组,数组元素的范围为[1,4]

for (int i = 0; i < ele.length; i++) {

tree.insert(ele[i]);

}

int k_nodes = tree.k_nodes(2);//第二层

int k_nodes2 = tree.k_nodes(-1);//第-1层

int k_nodes3 = tree.k_nodes(0);

int k_nodes4 = tree.k_nodes(1);

int k_nodes5 = tree.k_nodes(4);//若超过了树的高度,结果为0

System.out.println(k_nodes);

System.out.println(k_nodes2);

System.out.println(k_nodes3);

System.out.println(k_nodes4);

System.out.println(k_nodes5);

}

}

五,参考资料

http://blog.csdn.net/luckyxiaoqiang/article/details/7518888

https://www.cnblogs.com/hapjin/category/680818.html

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

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

相关文章

(vue基础试炼_02)使用vue.js实现隔2秒显示不同内容

接上一篇&#xff1a;&#xff08;vue基础试炼_01&#xff09;使用vue.js 快速入门hello worldhttps://gblfy.blog.csdn.net/article/details/103841156 文章目录一、原始js写法① 效果图② 2秒之后二、使用vue实现① 思考② vue写法③ 效果图三、vue总结一、原始js写法 <!…

适合小团队作战,奖金+招聘绿色通道,这一届算法大赛关注下?

大赛背景伴随着5G、物联网与大数据形成的后互联网格局的逐步形成&#xff0c;日益多样化的用户触点、庞杂的行为数据和沉重的业务体量也给我们的数据资产管理带来了不容忽视的挑战。为了建立更加精准的数据挖掘形式和更加智能的机器学习算法&#xff0c;对不断生成的用户行为事…

银行业AI:炒作背后的现实——“尽管对新技术感到兴奋,但银行业态度非常谨慎”

摘要&#xff1a; 在人工智能火热的今天&#xff0c;银行业是如何看待人工智能对其的影响呢&#xff1f;答案可能出人意料。随着人工智能的发展&#xff0c;越来越多的行业都或多或少会受到该技术的影响。在博主之前的文章中&#xff0c;分析了人工智能、大数据以及VR对教育行业…

tcp分包传图片 如何还原_技术控丨超详细解析TCP重传机制

作者&#xff1a;Zhang_Jiawen &#xff1b; 来自&#xff1a;Dell技术社区TCP 的主要任务是很简单&#xff1a;打包和发送数据。TCP 与其他协议的不同之处在于使用滑动窗口来管理基本数据收发过程&#xff0c;同时确保数据流的有效及可靠传输&#xff0c;从而不致发送速率明显…

超详细!上线一个机器学习项目你需要哪些准备?

摘要&#xff1a; Canvas是用于设计和记录机器学习系统的模板。它比简单的文本文档具有优势&#xff0c;因为Canvas用简单的部件通过部件之间的相关性来寻找机器学习系统的关键组件。这个工具已经很流行&#xff0c;因为它对复杂项目进行了可视化操作。 在本文中&#xff0c;我…

漫画:什么是插入排序?

戳蓝字“CSDN云计算”关注我们哦&#xff01;————— 第二天 —————————————————人们如何进行扑克牌的排序呢&#xff1f;举个例子&#xff0c;比如我手中有红桃6,7,9,10这四张牌&#xff0c;已经处于升序排列&#xff1a;这时候&#xff0c;我又抓到了一…

java.net.url 中文乱码_jsp get Url请求方式中文乱码问题解决办法

本文章来给大家介绍关于jsp get Url请求方式中文乱码问题解决办法&#xff0c;有需要的朋友可参考。jsp中post方式请求一般不会乱码&#xff0c;如果乱码加上这句&#xff1a;解决办法一代码如下复制代码request.setCharacterEncoding("utf-8");而get方式请求&#x…

(vue基础试炼_03)使用vue.js实现TodoList

接上一篇&#xff1a;&#xff08;vue基础试炼_02&#xff09;使用vue.js实现隔2秒显示不同内容https://gblfy.blog.csdn.net/article/details/103841818 指令作用v-for循环数据v-on绑定事件v-model数据的双向绑定文章目录一、需求说明① 案例文档② 基础代码③ 基础效果图二、…

Python API快餐教程(1) - 字符串查找API

摘要&#xff1a; 字符串查找API 字符串处理相关API 字符串是7种序列类型中的一种。除了序列的操作函数&#xff0c;比如len()来求字符串长度之外&#xff0c;Python还为字符串提供丰富到可以写个编辑器的API. 查找类API 首先&#xff0c;下面的查找API都是为了查找位置&#x…

python读取图像并相加_python使用PIL和matplotlib获取图片像素点并合并解析

python 版本 3.x首先安装 PIL由于PIL仅支持到Python 2.7&#xff0c;加上年久失修&#xff0c;于是一群志愿者在PIL的基础上创建了兼容的版本&#xff0c;名字叫Pillow&#xff0c;支持最新Python 3.x&#xff0c;又加入了许多新特性&#xff0c;因此&#xff0c;我们可以直接安…

因吵架总被骂,阿里程序猿一气之下发明“情侣吵架神器”

摘要&#xff1a; 最近&#xff0c;阿里有个叫虎跑的程序猿&#xff0c;发明了一个“吵架神器”。 到底是个什么黑科技&#xff1f; 最近&#xff0c;阿里有个叫虎跑的程序猿&#xff0c;发明了一个“吵架神器”。到底是个什么黑科技&#xff1f;和很多情侣一样&#xff0c;虎跑…

java中volatile关键字的含义_java中volatile关键字的含义

转自&#xff1a;http://www.cnblogs.com/aigongsi/archive/2012/04/01/2429166.html在java线程并发处理中&#xff0c;有一个关键字volatile的使用目前存在很大的混淆&#xff0c;以为使用这个关键字&#xff0c;在进行多线程并发处理的时候就可以万事大吉。Java语言是支持多线…

(vue基础试炼_04)使用组件改造TodoList

接上一篇&#xff1a;&#xff08;vue基础试炼_03&#xff09;使用vue.js实现TodoListhttps://gblfy.blog.csdn.net/article/details/103842233 指令说明v-bind传入绑定值文章目录一、前端页面组件化二、全局组件学习三、局部组件学习一、前端页面组件化 页面组件化&#xff1a…

我们到底该如何看待6G?

戳蓝字“CSDN云计算”关注我们哦&#xff01;近日&#xff0c;加拿大媒体报道&#xff0c;华为已确认在加拿大渥太华开启6G网络研究&#xff0c;已与加拿大多所大学的研究者展开洽谈。华为表示&#xff0c;自家的渥太华研发实验室将引领华为全球6G发展。图片来源网络消息传出之…

两年AI研究经验(教训)总结,进来看看吧!

摘要&#xff1a; 本文以过来人的身份将自身2年的研究经验做了一下分享&#xff0c;希望本文对于即将开始从事人工智能研究的朋友有所帮助。人工智能研究这个领域是有一定门槛的。对于初学者来说&#xff0c;一般通常的做法是直接购买一些热门的书籍&#xff0c;比如“西瓜书”…

C语言:字符串字面量及其保存位置

相关阅读 C语言https://blog.csdn.net/weixin_45791458/category_12423166.html?spm1001.2014.3001.5482 虽然C语言中不存在字符串类型&#xff0c;但依然可以通过数组或指针的方式保存字符串&#xff0c;但字符串字面量却没有想象的这么简单&#xff0c;本文就将对此进行讨论…

system.argumentnullexception值不能为null_MySQL NULL 值如何处理?

我们已经知道 MySQL 使用 SQL SELECT 命令及 WHERE 子句来读取数据表中的数据,但是当提供的查询条件字段为 NULL 时&#xff0c;该命令可能就无法正常工作。为了处理这种情况&#xff0c;MySQL提供了三大运算符:IS NULL: 当列的值是 NULL,此运算符返回 true。IS NOT NULL: 当列…

神经网络的优缺点

摘要&#xff1a; 深度学习目前受到了追捧。人们想将神经网络应用到各个地方&#xff0c;但是它们真的适合每个地方吗&#xff1f;在本篇文章中&#xff0c;将对于这个问题以及深度学习现在如此受追捧的原因进行讨论。通过这篇文章&#xff0c;您将了解神经网络的主要缺点&…

java配置jndi连接数_JavaWeb:Tomcat下配置数据源(JNDI)连接数据库 | 学步园

----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------习惯了以硬编码的形式在程序中建立数据库连接&#xff0c;用完就在finally语句…

(vue基础试炼_05)简单组件之间的传值

接上一篇&#xff1a;&#xff08;vue基础试炼_04&#xff09;使用组件改造TodoListhttps://gblfy.blog.csdn.net/article/details/103844256 文章目录一、上篇回顾① 代码欣赏② 代码分析二、子组件如何向父组件传值呢&#xff1f;① 需求案例文档② 需求案例效果图③ 思考与思…