Java语言描述二叉树的深度和宽度

 更新时间:2017年11月27日 17:19:10   作者:babylove_BaLe  
这篇文章主要介绍了Java语言描述二叉树的深度和宽度,具有一定借鉴价值,需要的朋友可以参考下。

解释:

二叉树的深度:从根结点到叶结点依次经过的结点(含根、叶结点)形成树的一条路径,最长路径的长度为树的深度。
二叉树的宽度:二叉树的每一层中都有一定数量的节点,节点数最多的那一层的节点数叫做二叉树的宽度。

思路:递归实现。

1.每个节点都可以看作根节点
2.根节点(任意一个节点)的深度等于它的左子树或右子树深度最大值+1
3.从根结点开始遍历,若遍历到叶子节点,深度为0

  //二叉树的深度
  public static int Depth(node root){
    if(root == null){
      return 0;
    }
    int dl = Depth(root.leftchild);
    int dr = Depth(root.rightchild);  
    return dl>dr? dl+1:dr+1;
  }

二、二叉树的宽度

思路:层序遍历时添加一个计数器,记录每层的节点数

1.每层出队列时记录下一层的节点数,其实就是队列的Size()
2.每层遍历结束时,比较最大宽度与当前层节点数,记录最大值

public static int Width(node root) {
	if(root == null)
	    return 0;
	Queue<node> q = new LinkedList<node>();
	q.add(root);
	int width = 1;
	//最大宽度
	int len = 1;
	//当前层节点数
	while(q.size()>0){
		while(len-->0){
			node node = q.poll();
			if(node.leftchild != null){
				q.add(node.leftchild);
			}
			if(node.rightchild != null){
				q.add(node.rightchild);
			}
		}
		len = q.size();
		//每层循环结束后记录下一层的节点数
		width = width>q.size() ? width : q.size();
	}
	return width;
}

总结

以上就是本文关于Java语言描述二叉树的深度和宽度的全部内容,希望对大家有所帮助。如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!

相关文章

  • Java基础之容器LinkedList

    Java基础之容器LinkedList

    这篇文章主要介绍了Java基础之容器LinkedList,文中有非常详细的代码示例,对正在学习java基础的小伙伴们有非常好的帮助,需要的朋友可以参考下
    2021-04-04
  • Java实战项目 健身管理系统

    Java实战项目 健身管理系统

    本文是一个Java语言编写的实战项目,是一个健身管理系统,主要用到了ssm+springboot等技术,技术含量笔记高,感兴趣的童鞋跟着小编往下看吧
    2021-09-09
  • 使用try-with-resource的输入输出流自动关闭

    使用try-with-resource的输入输出流自动关闭

    这篇文章主要介绍了使用try-with-resource的输入输出流自动关闭方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-07-07
  • 基于java Files类和Paths类的用法(详解)

    基于java Files类和Paths类的用法(详解)

    下面小编就为大家分享一篇基于java Files类和Paths类的用法详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2017-11-11
  • SpringBoot集成EasyExcel实现Excel导入的方法

    SpringBoot集成EasyExcel实现Excel导入的方法

    这篇文章主要介绍了SpringBoot集成EasyExcel实现Excel导入的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-01-01
  • 启用设置org.slf4j.Logger打印并输出日志方式

    启用设置org.slf4j.Logger打印并输出日志方式

    这篇文章主要介绍了启用设置org.slf4j.Logger打印并输出日志方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11
  • java poi 读取单元格null或者空字符串方式

    java poi 读取单元格null或者空字符串方式

    这篇文章主要介绍了java poi 读取单元格null或者空字符串方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-12-12
  • Java 深入理解创建型设计模式之原型模式

    Java 深入理解创建型设计模式之原型模式

    原型(Prototype)模式的定义如下:用一个已经创建的实例作为原型,通过复制该原型对象来创建一个和原型相同或相似的新对象。在这里,原型实例指定了要创建的对象的种类。用这种方式创建对象非常高效,根本无须知道对象创建的细节
    2022-02-02
  • Java List的sort()方法改写compare()实现升序,降序,倒序的案例

    Java List的sort()方法改写compare()实现升序,降序,倒序的案例

    这篇文章主要介绍了Java List的sort()方法改写compare()实现升序,降序,倒序的案例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-03-03
  • IDEA中sout快捷键无效问题的解决方法

    IDEA中sout快捷键无效问题的解决方法

    这篇文章主要介绍了IDEA中sout快捷键无效问题,在类文件中进行操作会造成sout快捷命令无法自动生成,比如操作了import引入其它包之后,本文给大家分享解决方法,感兴趣的朋友一起看看吧
    2022-07-07

最新评论