二叉树的性质及其创建

二叉树的性质及其创建二叉树的性质性质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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 线程池不使用 Executors 去创建,而是通过 ThreadPoolExecutor 的方式[通俗易懂]

    线程池不使用 Executors 去创建,而是通过 ThreadPoolExecutor 的方式

    2022年3月11日
    33
  • html静态页面代码_静态网页设计代码

    html静态页面代码_静态网页设计代码这个例子我们做一个游戏静态页面,自动跳转到我们想要玩的游戏或者视频等网站大家也可以根绝我的代码,适当修改一些信息,但是套用我的这个模板请注释下来自我这,我也是初学者,辛辛苦苦写了几个小时,尊重下劳动成果先看效果图:我以张杰为背景图,里面是各种网站跳转,比如我点击:冰火人,他就会跳转到4399的冰火人游戏界面。ok,上代码,我觉得比较简单,就没注释,希望能看懂:<!DOCTYPEhtml><html><headlang=”en”><metacha

    2022年9月23日
    3
  • winhttp 发送 get 请求「建议收藏」

    winhttp 发送 get 请求「建议收藏」由于微端要和服务器交互,而服务器又只有http协议的处理,所以需要用C++来模拟get或post请求。这是使用windowsapi来模拟get请求的,使用到的库有“winhttp”,头文件有“winhttp.h”,下面的代码来源于http://msdn.microsoft.com:12345678

    2022年7月27日
    8
  • python的缩进通常使用_python缩进格式

    python的缩进通常使用_python缩进格式Python中的缩进(Indentation)决定了代码的作用域范围。这一点和传统的c/c有很大的不同(传统的c/c使用花括号花括号{}符决定作用域的范围;python使用缩进空格来表示作用域的范围,相同缩进行的代码是处于同一范围)。每行代码中开头的空格数(whitespace)用于计算该行代码的缩进级别(Indentationlevel),注意一个Tab会被替换为1~8个Space(具…

    2022年10月10日
    1
  • 智能体脂秤解决方案[通俗易懂]

    这几年,随着智能科技的崛起,一大波智能产品纷纷上线,其中就有这不得不说的智能体脂秤。生活越来越富足的同时,体重也随之增长。人们对于健康的重视逐渐提升,体脂秤的功能也不只局限于称体重,还有很多一般体脂秤没有的功能。    智能体脂秤方案工作原理    智能秤其实是使用了生物电阻抗技术,在秤的表面加入了ITO导电膜或许导电金属片,当人体光脚踩上去之后会组成闭环电极,由于脂肪不导电而水分导电,所以可以通过计算电流值、电阻值配合体重值,来计算身体里脂肪的含量。换句话说,要测脂肪率,就必须赤脚上阵。   

    2022年4月9日
    102
  • matlab中 meshgrid 函数的用法

    matlab中 meshgrid 函数的用法转自:https://blog.csdn.net/foreverhuylee/article/details/32731349meshgrid是MATLAB中用于生成网格采样点的函数。在使用MATLAB进行3-D图形绘制方面有着广泛的应用。函数功能生成绘制3-D图形所需的网格数据。在计算机中进行绘图操作时,往往需要一些采样点,然后根据这些采样点来绘制出整个图形。在进行3-D绘图操作时,涉及到x、…

    2022年5月1日
    61

发表回复

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

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