文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

什么是二叉树与多叉树

2024-04-02 19:55

关注

这篇文章主要讲解了“什么是二叉树与多叉树”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“什么是二叉树与多叉树”吧!

一、树状结构

1、数组与链表

数组结构

数组存储是通过下标方式访问元素,查询速度快,如果数组元素是有序的,还可使用二分查找提高检索速度;如果添加新元素可能会导致多个下标移动,效率较低;

链表结构

链表存储元素,对于元素添加和删除效率高,但是遍历元素每次都需要从头结点开始,效率特别低;

树形结构能同时相对提高数据存储和读取的效率。

2、树结构概念

什么是二叉树与多叉树

树形结构是一层次的嵌套结构。一个树形结构的外层和内层有相似的结构,所以这种结构多可以递归的表示。经典数据结构中的各种树状图是一种典型的树形结构:一颗树可以简单的表示为根,  左子树, 右子树。 左子树和右子树又有自己的子树。

二、二叉树模型

什么是二叉树与多叉树

树的种类有很多,二叉树(BinaryTree)是树形结构的一个重要类型,每个节点最多只能有两个子节点的一种形式称为二叉树,二叉树的子节点分为左节点和右节点,许多实际问题抽象出来的数据结构往往是二叉树形式。

完全二叉树

什么是二叉树与多叉树

二叉树的所有叶子节点都在最后一层或者倒数第二层,而且最后一层的叶子节点在左边连续,倒数第二 层的叶子节点在右边连续,我们称为完全二叉树

满二叉树

什么是二叉树与多叉树

当二叉树的所有叶子节点都在最后一层,并且结点总数= 2^n -1 , n 为层数,则称为满二叉树。

平衡二叉树

什么是二叉树与多叉树

平衡二叉树指的是,任意节点的子树的高度差的绝对值都小于等于1,并且左右两个子树都是一棵平衡二叉树,常见的符合平衡树的有,B树(多路平衡搜索树)、AVL树(二叉平衡搜索树)等。

二叉查找树

什么是二叉树与多叉树

二叉查找树(BinarySearchTree)不但二叉树,同时满足一定的有序性:节点的左子节点比自己小,节点的右子节点比自己大。

三、二叉树编码

1、基础代码

节点代码

class TreeNode {     private String num ;     private TreeNode leftNode ;     private TreeNode rightNode ;     public TreeNode(String num) {         this.num = num;     }    @Override     public String toString() {         return "TreeNode{num=" + num +'}';     }}

树结构代码

class BinaryTree01 {     private TreeNode root ; }

2、遍历与查找

前序遍历查找

先处理当前结点的数据,再依次递归遍历左子树和右子树;

public void prevTraverse() {     // 输出父结点     System.out.println(this);     // 向左子树递归前序遍历     if(this.leftNode != null) {         this.leftNode.prevTraverse();     }    // 向右子树递归前序遍历     if(this.rightNode != null) {         this.rightNode.prevTraverse();     }}public TreeNode prevSearch(String num) {    //比较当前结点     if(this.num.equals(num)) {         return this ;     }    // 递归遍历左子树查找     TreeNode findNode = null;     if(this.leftNode != null) {         findNode = this.leftNode.prevSearch(num);     }    // 左子树遍历命中     if(findNode != null) {         return findNode ;     }    // 递归遍历右子树查找     if(this.rightNode != null) {         findNode = this.rightNode.prevSearch(num);     }    return findNode ; }

中序遍历查找

先递归遍历左子树,再处理父节点,再递归遍历右子树

public void midTraverse() {     // 向左子树递归中序遍历     if(this.leftNode != null) {         this.leftNode.midTraverse();     }    // 输出父结点     System.out.println(this);     // 向右子树递归中序遍历     if(this.rightNode != null) {         this.rightNode.midTraverse();     }}public TreeNode midSearch(String num) {    // 递归遍历左子树查找     TreeNode findNode = null;     if(this.leftNode != null) {         findNode = this.leftNode.midSearch(num);     }    if(findNode != null) {         return findNode ;     }    // 比较当前结点     if(this.num.equals(num)) {         return this ;     }    // 递归遍历右子树查找     if(this.rightNode != null) {         findNode = this.rightNode.midSearch(num);     }    return findNode ; }

后序遍历查找

先递归遍历左子树,再递归遍历右子树,最后处理父节点;

public void lastTraverse() {     // 向左子树递归后序遍历     if(this.leftNode != null) {         this.leftNode.lastTraverse();     }    // 向右子树递归后序遍历     if(this.rightNode != null) {         this.rightNode.lastTraverse();     }    // 输出父结点     System.out.println(this); }public TreeNode lastSearch(String num) {    // 递归遍历左子树查找     TreeNode findNode = null;     if(this.leftNode != null) {         findNode = this.leftNode.lastSearch(num);     }    if(findNode != null) {         return findNode ;     }    // 递归遍历右子树查找     if(this.rightNode != null) {         findNode = this.rightNode.lastSearch(num);     }    if(findNode != null) {         return findNode ;     }    // 比较当前结点     if(this.num.equals(num)) {         return this ;     }    return null ; }

3、删除节点

如果当前删除的节点是叶子节点,则可以直接删除该节点;如果删除的节点是非叶子节点,则删除该节点树。

public void deleteNode(String num) {     // 判断左节点是否删除     if(this.leftNode != null && this.leftNode.num.equals(num)) {         this.leftNode = null ;         return ;     }    // 判断右节点是否删除     if(this.rightNode != null && this.rightNode.num.equals(num)) {         this.rightNode = null;         return ;     }    // 向左子树遍历进行递归删除     if(this.leftNode != null) {         this.leftNode.deleteNode(num);     }    // 向右子树遍历进行递归删除     if(this.rightNode != null) {         this.rightNode.deleteNode(num);     }}

四、多叉树

什么是二叉树与多叉树

多叉树是指一个父节点可以有多个子节点,但是一个子节点依旧遵循一个父节点定律,通常情况下,二叉树的实际应用高度太高,可以通过多叉树来简化对数据关系的描述。

例如:Linux文件系统,组织架构关系,角色菜单权限管理系统等,通常都基于多叉树来描述。

感谢各位的阅读,以上就是“什么是二叉树与多叉树”的内容了,经过本文的学习后,相信大家对什么是二叉树与多叉树这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯