树和二叉树

文章目录

  • 树和二叉树
    • 1.树的概念
    • 1.1特点
    • 1.2基本概念
  • 2.二叉树
    • 2.1二叉树的定义
    • 2.2特殊的树
    • 2.3 二叉树的性质
    • 2.4二叉树的存储
  • 二叉树的遍历

树和二叉树

1.树的概念

树是一种非线性的数据结构,它是由n个有限结点组成一个有具体层次关系的集合

1.1特点

没有前驱结点的特殊节点称为根结点

除根结点外,其余结点被分成M(M>0)个互不相交的集合,其中每个集合是一颗颗与树类似的子树。

每棵子树的根结点有且只有一个前驱,可以有0个或多个后继

树是递归定义

注意:在树形结构中,子树之间不能有交集
在这里插入图片描述

除了根结点外,每个结点有且仅有一个父节点
在这里插入图片描述
一颗N个结点的树有N-1条边
在这里插入图片描述
树的示意图
在这里插入图片描述

1.2基本概念

结点的度:一个结点含有子树的个数,如示意图,A的度为3,E的度为1, J的度为0

树的度:一棵树中,所有结点度的最大值,如示意图,树的度为3
叶子结点:度为0的节点,如示意图,叶子结点是F、H、I、J、K、L
双亲结点:若一个结点含有子结点,则这个结点称其为子结点的双亲结点
父结点: 如示意图,E是J的父结点,B是E和F的父结点
根结点:一颗树中,没有双亲结点的结点,如示意图,根节点是A
子结点:一个结点含有的子树的根结点称为该结点的子结点,如示意图,B的子结点是E、F

2.二叉树

2.1二叉树的定义

一棵二叉树是结点的一个有限集合,该集合可以为空,也可以是由一个根节点加上两棵别称为左子树和右子树的二叉树组成。
在这里插入图片描述
注意

  1. 二叉树不存在度大于2的结点
  2. 二叉树的子树有左右之分,次序不能颠倒,因此二叉树是有序树

2.2特殊的树

满二叉树: 一棵二叉树,如果每层的结点数都达到最大值,则这棵二叉树就是满二叉树。
换句话说,如果一棵二叉树的层数为K,且结点总数是 N=2^K-1,则它就是满二叉树
在这里插入图片描述

完全二叉树:完全二叉树是由满二叉树而引出来的。对于深度为K的,有n个结点的二叉树,当且仅当其每一个结点都与深度为K的满二叉树中编号从0至n-1的结点一一对应时称之为完全二叉树。
在这里插入图片描述

注意:满二叉树是一种特殊的完全二叉树。

2.3 二叉树的性质

  1. 若规定根结点的层数为1,则一棵非空二叉树的第i层上最多有2^i-1 (i>0)个结点
  2. 若规定只有根结点的二叉树的深度为1,则深度为K的二叉树的最大结点数是 N=2^k-1
  3. . 对任何一棵二叉树, 如果其叶结点个数为 n0, 度为2的非叶结点个数为 n2,则有n0=n2+1

假设节点总数是N,如果度为0其叶子结点树为n0,度为1的子节点个数为n1,度为2的子节点数为n2
节点总数:N=n0+n1+n2
又因为性质:二叉树的边比节点数少1
N=n1+2n2+1

联立得n0=n2+1

  1. 具有n个结点的完全二叉树的深度k为log2(n+1) 向上取整

  2. 对于具有n个结点的完全二叉树,如果按照从上至下从左至右的顺序对所有节点从0开始编号,则对于序号为i的结点有:

     若i>0,双亲序号:(i-1)/2;i=0,i为根结点编号,无双亲结点若2i+1<n,**左孩子序号:2i+1**,否则无左孩子若2i+2<n,**右孩子序号:2i+2**,否则无右孩子
    

2.4二叉树的存储

顺序存储
我们可以通过双亲节点与子节点下标之间的映射关系将二叉树存储在数组中,如果节点为空,我们以INT_MAX来标记。
在这里插入图片描述

链式存储

class TreeNode {int val;TreeNode left;//左孩子TreeNode right;//右孩子public TreeNode(int val) {this.val = val;//当前节点值}
}

二叉树的遍历

前序遍历
根节点 → 左子树 → 右子树

递归实现

// 前序遍历
void preOrder(TreeNode root) {if (root == null) return;System.out.print(root.val + " ");preOrder(root.left);preOrder(root.right);
}

非递归实现(使用栈)

// 前序遍历(非递归)
void preOrder(TreeNode root) {Stack<TreeNode> stack = new Stack<>();TreeNode cur = root;while (cur != null || !stack.isEmpty()) {while (cur != null) {System.out.print(cur.val + " ");stack.push(cur);cur = cur.left;}cur = stack.pop().right;}
}

中序遍历

左子树 → 根节点 → 右子树

递归实现

// 中序遍历
void inOrder(TreeNode root) {if (root == null) return;inOrder(root.left);System.out.print(root.val + " ");inOrder(root.right);
}

非递归实现

// 中序遍历(非递归)
void inOrder(TreeNode root) {Stack<TreeNode> stack = new Stack<>();TreeNode cur = root;while (cur != null || !stack.isEmpty()) {while (cur != null) {stack.push(cur);cur = cur.left;}cur = stack.pop();System.out.print(cur.val + " ");cur = cur.right;}
}

后序遍历

左子树 → 右子树 → 根节点

递归实现

// 后序遍历
void postOrder(TreeNode root) {if (root == null) return;postOrder(root.left);postOrder(root.right);System.out.print(root.val + " ");
}

非递归实现

// 后序遍历(非递归,双栈法)
void postOrder(TreeNode root) {Stack<TreeNode> s1 = new Stack<>();Stack<TreeNode> s2 = new Stack<>();s1.push(root);while (!s1.isEmpty()) {TreeNode node = s1.pop();s2.push(node);if (node.left != null) s1.push(node.left);if (node.right != null) s1.push(node.right);}while (!s2.isEmpty()) System.out.print(s2.pop().val + " ");
}
遍历方式时间复杂度空间复杂度(递归/非递归)典型应用场景
前序遍历O(n)O(h)复制二叉树、前缀表达式
中序遍历O(n)O(h)二叉搜索树排序、中缀表达式
后序遍历O(n)O(h)内存释放、后缀表达式

层序遍历
每一层一次遍历,需要借助队列实现
在这里插入图片描述
实现步骤:

  1. 根节点入队
  2. 循环出队并访问节点
  3. 将当前节点的子节点入队
  4. 重复直到队列为空
List<List<Integer>> levelOrder(TreeNode root) {List<List<Integer>> res = new ArrayList<>();if(root == null) return res;Queue<TreeNode> queue = new LinkedList<>();queue.offer(root);while(!queue.isEmpty()){int levelSize = queue.size();//记录当前层的节点数List<Integer> level = new ArrayList<>();for(int i=0; i<levelSize; i++){TreeNode node = queue.poll();level.add(node.val);if(node.left != null) queue.offer(node.left);if(node.right != null) queue.offer(node.right);}res.add(level);}return res;//输出列表
}

因为每个节点被访问一次,所以时间复杂度是O(n)
当树完全不平衡时,队列中需要存储所有节点,所以空间复杂度在最坏情况下是O(n)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/24615.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ubuntu离线安装Ollama并部署Llama3.1 70B INT4

文章目录 1.下载Ollama2. 下载安装Ollama的安装命令文件install.sh3.安装并验证Ollama4.下载所需要的大模型文件4.1 加载.GGUF文件&#xff08;推荐、更容易&#xff09;4.2 加载.Safetensors文件&#xff08;不建议使用&#xff09; 5.配置大模型文件 参考&#xff1a; 1、 如…

15.代码随想录算法训练营第十五天|(递归)110. 平衡二叉树,257. 二叉树的所有路径*,404. 左叶子之和,222.完全二叉树的节点个数[打卡自用]

15.代码随想录算法训练营第十五天|&#xff08;递归&#xff09;110. 平衡二叉树&#xff0c;257. 二叉树的所有路径*&#xff0c;404. 左叶子之和&#xff0c;222.完全二叉树的节点个数 给定一个二叉树&#xff0c;判断它是否是 平衡二叉树 示例 1&#xff1a; 输入&#xf…

GateWay

文章目录 创建网关配置路由规则工作原理 断言过滤器默认filter全局跨域 左边的是响应式网关&#xff0c;右边是传统网关(Servlet年代) 推荐左边的 需求 创建网关 在服务模块外 新建一个gateway模块 导入依赖&#xff0c;nacos和gateway和负载均衡 配置一下 这里网关默认占80…

十一、大数据治理平台总体功能架构

大数据治理平台的功能架构图中心主题&#xff1a;数据治理 核心重点是建立健全大数据资产管理框架&#xff0c;确保数据质量、安全性、可访问性和合规性。 大数据治理平台总体功能架构图 关键功能领域 1.数据资产平台&#xff08;左侧&#xff09; 此部分主要关注数据资产本身…

网络安全 机器学习算法 计算机网络安全机制

&#xff08;一&#xff09;网络操作系统 安全 网络操作系统安全是整个网络系统安全的基础。操作系统安全机制主要包括访问控制和隔离控制。 访问控制系统一般包括主体、客体和安全访问政策 访问控制类型&#xff1a; 自主访问控制强制访问控制 访问控制措施&#xff1a; 入…

PDF扫描档智能方向识别:多模型投票机制的实践测试 救活古典书籍

2025-02-22 20:10物联全栈123 尊敬的诸位&#xff01;我是一名物联网工程师。关注我&#xff0c;持续分享最新物联网与AI资讯和开发实战。期望与您携手探寻物联网与 AI 的无尽可能 RAG知识库搭建的过程中&#xff0c;扫描档pdf的支持和准确率一直是个大家都不愿主动提起的事情…

初会学习记录

【25初级会计《实务》】第一章&#xff1a;权责发生制举例_哔哩哔哩_bilibili 务实&#xff1a; 第一章 (1)会计概念&#xff0c;职能和目标&#xff1a; 2025年2月25日&#xff1a; (2)会计假设&#xff1a; 2025年2月26日&#xff1a; (3)会计核算基础&#xff1a; 202…

【FL0091】基于SSM和微信小程序的社区二手物品交易小程序

&#x1f9d1;‍&#x1f4bb;博主介绍&#x1f9d1;‍&#x1f4bb; 全网粉丝10W,CSDN全栈领域优质创作者&#xff0c;博客之星、掘金/知乎/b站/华为云/阿里云等平台优质作者、专注于Java、小程序/APP、python、大数据等技术领域和毕业项目实战&#xff0c;以及程序定制化开发…

【DDD系列-10】一页纸回顾DDD

1. DDD是什么 DDD&#xff1a; 是 Domain-Driven Design 的缩写&#xff0c;是 Eric Evans (埃里克•埃文斯)于 2004 年提出的一种软件设计方法和理念。其主要的思想是&#xff0c;利用确定的业务模型来指导业务与应用的设计和实现。主张开发人员与业务人员持续地沟通和模型的…

【视频2 - 4】初识操作系统,Linux,虚拟机

&#x1f4dd;前言说明&#xff1a; ●本专栏主要记录本人的基础算法学习以及LeetCode刷题记录&#xff0c;主要跟随B站博主灵茶山的视频进行学习&#xff0c;专栏中的每一篇文章对应B站博主灵茶山的一个视频 ●题目主要为B站视频内涉及的题目以及B站视频中提到的“课后作业”。…

逆向pyinstaller打包的exe软件,获取python源码(5)

在ailx10&#xff1a;逆向pyinstaller打包的exe软件&#xff0c;获取python源码(2)中&#xff0c;我们已经逆向出了主程序&#xff0c;但是import导入的py文件并没有被逆向出来&#xff0c;今天在知乎网友给的提醒下&#xff0c;说是在 PYZ-00.pyz_extracted 文件夹中&#xff…

快速理解Raft分布式共识算法

目录 拜占庭将军问题 Raft算法是干什么的&#xff1f; 一、领导选举&#xff08;选老板&#xff09; 二、日志复制&#xff08;发通知&#xff09; 三、安全性&#xff08;防篡改&#xff09; &#x1f330; 举个真实例子 ✔️ Raft的优势 基础 状态机 节点类型 任期…

mmdetection框架下使用yolov3训练Seaships数据集

之前复现的yolov3算法采用的是传统的coco数据集&#xff0c;这里我需要在新的数据集上跑&#xff0c;也就是船舶检测方向的SeaShips数据集&#xff0c;这里给出教程。 Seaships论文链接&#xff1a;https://ieeexplore.ieee.org/stamp/stamp.jsp?tp&arnumber8438999 一、…

方法的有关知识(含递归)

方法使用 方法就是一个 代码片段 . 类似于 C 语言中的 " 函数 " 。 方法(代码片段)定义: public class Method{ // 方法的定义public static int add(int x, int y) {return x y;} }修饰符(public static) 返回值类型 方法名称([参数类型 形参]){ 方法体代码;…

公链开发与公链生态开发:构建未来区块链世界的基石

在区块链技术日新月异的今天&#xff0c;公链&#xff08;Public Blockchain&#xff09;作为去中心化网络的核心&#xff0c;不仅为数字资产交易提供了坚实的基础&#xff0c;更推动了智能合约、去中心化应用&#xff08;DApps&#xff09;等生态系统的蓬勃发展。公链开发与公…

python+django+transformers模型:实现商品推荐功能(集成nacos配置,数据端mongo)

一、环境安装准备 #创建 虚拟运行环境python -m venv myicrplatenv#刷新source myicrplatenv/bin/activate#python Django 集成nacospip install nacos-sdk-python#安装 Djangopip3 install Django5.1#安装 pymysql settings.py 里面需要 # 强制用pymysql替代默认的MySQLdb pym…

vue3-07模拟vue3的响应式原理Proxy (代理对象)与Reflect (反射对象)

1.实现原理 通过Proxy (代理对象): 拦截对象中任意属性的变化,包括: 性值的读写、性的添加、属性的删除。通过Reflect (反射对象): 对源对象的属性进行操作。 new Proxy(data,{ // 拦截读取属性值 get (target, prop) ( return Reflect.get(target, prop) // 拦截设置属性值或…

微信小程序源码逆向 MacOS

前言 日常工作中经常会遇到对小程序的渗透测试&#xff0c;微信小程序的源码是保存在用户客户端本地&#xff0c;在渗透的过程中我们需要提取小程序的源码进行问题分析&#xff0c;本篇介绍如何在苹果电脑 MacOS 系统上提取微信小程序的源码。 0x01 微信小程序提取 在苹果电…

Python 3.12安装流程

一、下载Python安装包 访问Python官网&#xff1a;Python.org 点击 Download Python 3.12按钮&#xff08;自动识别您的操作系统&#xff09;。 二、运行安装程序 找到下载的安装文件&#xff08;如 python-3.12.3-amd64.exe&#xff09;&#xff0c;双击运行。 勾选 Add py…

【2025.2.25更新】wordpress免费AI插件,文章内容、图片自动生成、视频自动生成、网站AI客服、批量采集文章,内置deepseek联网满血版

wordpress免费AI插件&#xff0c;文章内容、文章图片、长尾关键词、视频自动生成、网站AI客服、批量采集文章&#xff0c;插件已接入腾讯云大模型知识引擎xDeepSeek&#xff0c;基于腾讯云大模型知识引擎xDeepSeek可联网满血版&#xff0c;插件可实现文章生成、长尾关键词生成、…