二叉树的性质及其创建

二叉树的性质及其创建二叉树的性质性质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)
上一篇 2022年5月15日 下午3:20
下一篇 2022年5月15日 下午3:20


相关推荐

  • cmd中实现代码雨的命令。。。「建议收藏」

    cmd中实现代码雨的命令。。。「建议收藏」颜色修改时不能使用十六进制数@echoofftitledigitalraincolor0bsetlocalENABLEDELAYEDEXPANSIONfor/l%%iin(0)

    2022年8月5日
    9
  • 网络传真和传真服务器[通俗易懂]

    网络传真和传真服务器[通俗易懂]传真机自1906年在德国推出以来,到今天已走过一百多年的历史,传真的形式也从最早的机械传真、光电传真、数字传真发展到今天的电子传真、电脑传真、网络传真、无纸传真、传真系统、传真服务器、传真软件、传真卡等。   所谓电子传真机(包括各种类型的网络传真机、电脑传真机、数码传真机、无纸传真机、传真软件、传真系统、传真服务器等,下同),就是通过电脑收发传真。     在发送传真前,自动检

    2022年6月28日
    33
  • 搭建Gateway网关服务

    搭建Gateway网关服务搭建Gateway网关服务

    2022年10月11日
    3
  • linux 卸载软件三种方式「建议收藏」

    linux 卸载软件三种方式「建议收藏」1.我们来卸载用yum安装的软件:yumremove软件名字;2.如果是用rpm包安装的软件呢,则使用如图命令进行卸载;rpm-e软件名;3.如果是用tar包安装的软件呢,则使用makeuninstall软件名称来卸载,直接删除也可以的;…

    2025年10月14日
    3
  • 配置域控服务器

    配置域控服务器将一台成员服务器提升为域服务器 域控制器 的步骤 nbsp 目前很多公司的网络中的 PC 数量均超过 10 台 按照微软的说法 一般网络中的 PC 数目低于 10 台 则建议采对等网的工作模式 而如果超过 10 台 则建议采用域的管理模式 因为域可以提供一种集中式的管理 这相比于对等网的分散管理有非常多的好处 下面讲解如何把一台成员服务器提升为域控制器 本篇文章中所有的成员服务器均采用微软的 Windows

    2026年3月19日
    2
  • sdn和nfv是什么_他她它怎么区分

    sdn和nfv是什么_他她它怎么区分那到底什么是NFV(网络功能虚拟化),它和之前的SDN(Software-definedNetworking)软件定义网络概念是一回事吗?它们有什么区别?SDN-诞生于校园,成熟于数据中心:SDN初始于园区网络,一群研究者(斯坦福的达人们)在进行科研时发现,每次进行新的协议部署尝试时,都需要改变网络设备的软件,这让他们非常郁闷,于是乎,他们开始考虑让这些网络硬件设备可编程化,并且可以被集中的一个盒子所管理和控制,就这样,诞生了当今SDN的基本定义和元素·分离控制和转发的功能·

    2025年10月11日
    4

发表回复

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

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