二叉树的性质及其创建

二叉树的性质及其创建二叉树的性质性质1在二叉树的第i层上至多有2^(i-1)个结点(i>=1)性质2深度为k的二叉树至多有2^k-1个结点(k>=1)性质3对任意一棵二叉树,若终端结点数为n0,其度数为2的结点数为n2,那么n0=n2+1满二叉树深度为k且结点个数为2^k-1,即每一层都具有最大结点数完全二叉树深度为k,结点数为n的二叉树,如果其结点1n的位置序号分别与满二叉树的结点1…

大家好,又见面了,我是你们的朋友全栈君。

二叉树的性质
性质1
在二叉树的第i层上至多有2^(i-1)个结点(i>=1)
性质2
深度为k的二叉树至多有2^k-1个结点(k>=1)
性质3
对任意一棵二叉树,若终端结点数为n0,其度数为2的结点数为n2,那么n0=n2+1
满二叉树
深度为k且结点个数为2^k-1,即每一层都具有最大结点数
完全二叉树
深度为k,结点数为n的二叉树,如果其结点1n的位置序号分别与满二叉树的结点1n的位置序号对应,则为完全二叉树
性质4
具有n个结点的完全二叉树的深度为ceil[log(2)(n)]+1
性质5
具有n个结点的完全二叉树,结点的序号i满足
①i=1,结点i为根结点
②2i>n,结点i无左孩子;2i<n,结点i的左孩子序号为2i
③2i+1>n,结点i无右孩子;2i+1<n,结点i的右孩子序号为2i+1

统计叶子结点的个数

// 统计叶子结点的个数
public int num_n0Node(BiTreeNode tree) { 
   
    if (tree.lchild==null && tree.rchild==null)
        return 1;
    if (tree == null)
        return 0;
    return num_n0Node(tree.lchild) + num_n0Node(tree.rchild);
}

求二叉树的深度

// 求二叉树的深度
public int height(BiTreeNode tree) { 
   
    if (tree==null)
        return 0;
    int left = height(tree.lchild);
    int right = height(tree.rchild);
    return (left > right ? left : right) + 1;
}

打印树状二叉树

// 打印树状二叉树
public void PrintBiTree(BiTreeNode tree, int nLayer) { 
   
    if (tree != null){ 
   
        PrintBiTree(tree.rchild, nLayer + 1);
        for (int i = 0; i < nLayer; i++)
            System.out.print(" ");  // 第几层data之前就空几个
        System.out.println(tree.data);
        PrintBiTree(tree.lchild, nLayer + 1);
    }
}

先序创建一棵二叉树

二叉树的结点结构

class BiTreeNode { 
   
    int data;   // 结点的信息
    BiTreeNode lchild, rchild;  // 左右孩子指针
}

过程

public BiTreeNode Create() { 
   	// 先输入一个结点,已'#'代表null
    String s = scanner.nextLine();
    if ("#".equals(s))
        return null;
    int i = Integer.parseInt(s);
    BiTreeNode node = new BiTreeNode(i, Create(), Create());	// 创建结点,再递归创建它的左右结点
    return node;
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/146251.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • EasyBoot使用方法

    EasyBoot使用方法1修改背景图片直接替换掉EasyBoot\disk1\ezboot目录下面的BACK.BMP文件即可。但是限于DOS功能限制,只能使用640×480像素,256位色的BMP图片。2鼠标

    2022年7月4日
    20
  • 函数指针的用法

    函数指针的用法

    2021年11月20日
    45
  • ideal2019 30天试用结束了,在线激活码【最新永久激活】

    (ideal2019 30天试用结束了,在线激活码)这是一篇idea技术相关文章,由全栈君为大家提供,主要知识点是关于2021JetBrains全家桶永久激活码的内容IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html2JTX0APX6F-eyJsa…

    2022年3月30日
    42
  • pycharm下载pandas包失败_pycharm下载包很慢

    pycharm下载pandas包失败_pycharm下载包很慢Pycharm使用安装各种包下载速度慢问题快捷键安装各种包python3-mpipinstallnumpy控制台用这段代码,所有包应该都可以下载下载速度慢问题pip下载速度一般几十k,下着下着就超时了,我用这个大佬的方法解决了MAC下的这个问题MAC解决pip3下载速度慢的问题快捷键最后记录一些经常用的MACPycharm快捷键,方便使用option+commend+L代码格式化control+r运行commend+backspace删除光标所在行

    2022年8月29日
    6
  • 留言板的代码_留言板留言大全短句

    留言板的代码_留言板留言大全短句<!DOCTYPEhtml><htmllang=”en”><head><metacharset=”UTF-8″><metahttp-equiv=”X-UA-Compatible”content=”IE=edge”><metaname=”viewport”content=”width=device-width,initial-scale=1.0″><title>D.

    2022年10月21日
    2
  • java 物理删除和逻辑删除

    java 物理删除和逻辑删除java物理删除和逻辑删除逻辑删除:文件没有被真正的删除,只不过是文件名的第一个字节被改成操作系统无法识别的字符,通常这种删除操作是可逆的,就是说用适当的工具或软件可以把删除的文件恢复出来。物理删除:指文件存储所用到的磁存储区域被真正的擦除或清零,这样删除的文件是不可以恢复的物理删除是计算机处理数据时的一个概念。与物理删除相对应的是逻辑删除。逻辑删除就是对要要删除的数据打上一个删除标记,在逻辑上是数据是被删除的,但数据本身依然存在!而物理删除则是把数据从介质上彻底删除掉。配置逻辑删除的步骤:

    2022年5月31日
    119

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号