【数据结构】二叉树的递归

数据结构系列三:二叉树(二)

一、递归的原理

1.全访问

2.主角

3.返回值

4.执等

二、递归的化关系思路

三、递归的方法设计


一、递归的原理

1.全访问

方法里调用方法自己,就会形成调用方法本身的一层一层全新相同的调用方法的形参设置为根的左右子根访问,方法调用时就会自动去访问一次树的左右根一个方法根会调用里面方法访问它的左右子根、而调用着的是两个全新和它相同的、属于着它的方法,下一层的左子根同样会去调用着属于它的它下一层的左右子根两方法,下一层的右子根也同样会去调用着属于它的它下一层的左右子根两方法,每一个全新的方法都会去调用着属于在它里面的它下一层左右子根的两个全新相同的也会去调用它们各自左右子根两全新相同的方法,这样每个根方法里面都会有对应的同样访问两子根方法本身再去调访问它左右子根的又左右子根的相同方法,从上到下每个根都会被属于进而被调用着、去调用着而被全访问到


2.主角

从上到下每个根都有去被调用成方法的形参做方法的主角,除了最上层根没有上层不被作子角被带着、最下层null作主角里面却不带有子角每个根都会作主角里面带着子角被作子角被上层主角带着


3.返回值

主角最重要的是它方法的返回值,主角里调用产生属于它的子主角卡等着执等着子主角执行完后成返回值当null成主角时会直接成为返回值每一个主角成返回值都会促使上层主角变着成返回值也再去促使着它再上一层主角也成返回值也去促使着上层

从下往上汇着促着主角们从下往上推着翻着成为返回值,最后全部变为返回值推着到最上层的也成一个返回值最后结束


4.执等

每个主角们卡着执着等着左右根主角都是先执等着进左主角再执等着进右主角等返回值

  • 如果执等的主角是null,进去null作为主角的方法是立即成返回值的使得执等着null的主角是能立马得到返回值促使的
  • 如果执等的主角是根主角,进去根节点作为主角的往往它变成返回值需要长时间的回应使得执卡着的

二、递归的化关系思路

因为主角们都是完全相同性质的主角,主角最后都是返回值都是结果,然后结构都是上一层的一个结果用它下一层的两个结果化得到再两层两层无缝循环作为结果与另一个结果再拼接再化成上一层的一个结果,结构都是下一层的两结果化为上一层的一个结果一层上一层、重复地往上化,所以只要知道了上一层的一个结果与下一层的两个结果之间的化关系在此种结构下就能设计成循环地向上化出结果

三、递归的方法设计

知道上一层结果与下一层的两结果之间的化关系后从最下两层开始

  1. 先设计就只有这两层的倒2层是总结果的化设计
  2. 设计好后再设计再往上多一层跳到它这层主角里面对刚已设计好的下层的主角返回值接收处那边再设计

从最下两层的设计再往上爬上两层的设计,递归方法就总体设计好了

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

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

相关文章

Imgui处理glfw的鼠标键盘的方法

在Imgui初始化时,会重新接手glfw的键盘鼠标事件。也就是遇到glfw的键盘鼠标事件时,imgui先会运行自己的处理过程,然后再去处理用户自己注册的glfw的键盘鼠标事件。 看imgui_impl_glfw.cpp源码的安装回调函数部分代码 void ImGui_ImplGlfw_In…

【LVS】负载均衡群集部署(DR模式)

部署前IP分配 DR服务器:192.168.166.101 vip:192.168.166.100 Web服务器1:192.168.166.104 vip:192.168.166.100 Web服务器2:192.168.166.107 vip:192.168.166.100 NFS服务器:192.168.166.108 …

C++Primer学习(14.1 基本概念)

当运算符作用于类类型的运算对象时,可以通过运算符重载重新定义该运算符的含义。明智地使用运算符重载能令我们的程序更易于编写和阅读。举个例子,因为在Sales_item类中定义了输入、输出和加法运算符,所以可以通过下述形式输出两个Sales_item…

计算机视觉准备八股中

一边记录一边看,这段实习跑路之前运行完3DGAN,弄完润了,现在开始记忆八股 1.CLIP模型的主要创新点: 图像和文本两种不同模态数据之间的深度融合、对比学习、自监督学习 2.等效步长是每一步操作步长的乘积 3.卷积层计算输入输出…

基于大语言模型的智能音乐创作系统——从推荐到生成

一、引言:当AI成为音乐创作伙伴 2023年,一款由大语言模型(LLM)生成的钢琴曲《量子交响曲》在Spotify冲上热搜,引发音乐界震动。传统音乐创作需要数年专业训练,而现代AI技术正在打破这一壁垒。本文提出一种…

Mysql---锁篇

1:MySQL 有哪些锁? 全局锁 flush tables with read lock 整个数据库就处于只读状态了 unlock tables 释放全局锁 全局锁主要应用于做全库逻辑备份,这样在备份数据库期间,不会因为数据或表结构的更新,而出现备份文件的数…

VLAN综合实验二

一.实验拓扑: 二.实验需求: 1.内网Ip地址使用172.16.0.0/分配 2.sw1和SW2之间互为备份 3.VRRP/STP/VLAN/Eth-trunk均使用 4.所有Pc均通过DHCP获取IP地址 5.ISP只能配置IP地址 6.所有…

GEO(生成引擎优化)实施策略全解析:从用户意图到效果追踪

——基于行业实证的AI信源占位方法论 ​一、理解用户查询:构建AI语料的核心起点 生成式AI的内容推荐逻辑以用户意图为核心,​精准捕捉高频问题是GEO优化的第一步。企业需通过以下方法挖掘用户真实需求: ​AI对话日志分析: 分析用…

HTML基础及进阶

目录 一、HTML基础 1.什么是HTML 2.常用标签 (1)标题标签:h1-h6数字越小文字会越大,这个标签会占一整行 (2)加粗标签: (3)换行标签: (4&am…

MSTP与链路聚合技术

MSTP(多生成树协议) 简介 MSTP(多生成树协议)是Spanning Tree Protocol(STP)的改进版,支持网络中使用多条生成树,并根据用户需求限制生成树间的路径。MSTP将多个VLAN映射到一棵生成…

ModuleNotFoundError: No module named ‘ml_logger.logbook‘

问题 (legion) zhouy24RL-DSlab:~/zhouy24Files/legion/LEGION$ python main.py ML_LOGGER_USER is not set. This is required for online usage. Traceback (most recent call last): File “main.py”, line 7, in from mtrl.app.run import run File “/data/zhouy24File…

c# ftp上传下载 帮助类

工作中FTP的上传和下载还是很常用的。如下载打标数据,上传打标结果等。 这个类常用方法都有了:上传,下载,判断文件夹是否存在,创建文件夹,获取当前目录下文件列表(不包括文件夹) ,获取当前目录下文件列表(不包括文件夹) ,获取FTP文件列表(包括文件夹), 获取当前目…

PyTorch 分布式训练(Distributed Data Parallel, DDP)简介

PyTorch 分布式训练(Distributed Data Parallel, DDP) 一、DDP 核心概念 torch.nn.parallel.DistributedDataParallel 1. DDP 是什么? Distributed Data Parallel (DDP) 是 PyTorch 提供的分布式训练接口,DistributedDataPara…

策略模式_行为型_GOF23

策略模式 策略模式(Strategy Pattern)是一种行为型设计模式,核心思想是将一组算法封装成独立对象,使它们可以相互替换,从而让算法的变化独立于使用它的客户端。这类似于游戏中的技能切换——玩家根据战况选择不同技能…

【Python】天气数据可视化

1. Python进行数据可视化 在数据分析和科学计算领域,Python凭借其强大的库和简洁的语法,成为了众多开发者和科研人员的首选工具。数据可视化作为数据分析的重要环节,能够帮助我们更直观地理解数据背后的规律和趋势。本文将详细介绍如何使用P…

深度学习4.4笔记

《动手学深度学习》-4.4-笔记 验证数据集:通常是从训练集中划分出来的一部分数据,不要和训练数据混在一起,评估模型好坏的数据集 测试数据集:只用一次的数据集 k-折交叉验证(k-Fold Cross-Validation)是…

vue 两种路由模式

一、两种模式比较 在vue.js中,路由模式分为两种:hash 模式和 history 模式。这两种模式决定了URL的结构和浏览器历史记录的管理方式。 1. hash 模式带 #,#后面的地址变化不会引起页面的刷新。换句话说,hash模式不会将#后面的地址…

Android生态大变革,谷歌调整开源政策,核心开发不再公开

“开源”这个词曾经是Android的护城河,如今却成了谷歌的烫手山芋。最近谷歌宣布调整Android的开源政策,核心开发将全面转向私有分支。翻译成人话就是:以后Android的核心更新,不再公开共享了。 这操作不就是开源变节吗,…

JavaScript中集合常用操作方法详解

JavaScript中集合常用操作方法详解 JavaScript中的集合主要包括数组(Array)、集合(Set)和映射(Map)。下面我将详细介绍这些集合类型的常用操作方法。 数组(Array) 数组是JavaScript中最常用的集合类型,提供了丰富的操作方法。 创建数组 // 字面量创建 const ar…

【HC-05】蓝牙串口通信模块调试与应用(1)

一、HC-05 基础学习视频 HC-05蓝牙串口通信模块调试与应用1 二、HC-05学习视频课件