【递归搜索回溯专栏】前言与本专栏介绍

本专栏内容为:递归,搜索与回溯算法专栏。 通过本专栏的深入学习,你可以了解并掌握算法。

💓博主csdn个人主页:小小unicorn
⏩专栏分类:递归搜索回溯专栏
🚚代码仓库:小小unicorn的代码仓库🚚
🌹🌹🌹关注我带你学习编程知识

前言

  • 递归
    • 什么是递归
    • 为什么会用到递归
    • 如何理解递归
    • 怎样写好递归
  • 搜索
    • 深度优先/宽度优先
    • 关系图
    • 拓展搜索
  • 回溯与剪枝

递归

什么是递归

在讲解递归前,我们首先要知道什么是递归:
递归我们之前是接触过的:
在c语言中我们详细学过递归,数据结构中的快排,二叉树也用到了递归。

简单来说,递归就是函数自己调用自己。

为什么会用到递归

那么为什么会用到递归呢?
举两个例子:
例子一
在这个二叉树中:我们用前序遍历来遍历这个树:
在这里插入图片描述
先访问蓝色节点,然后将这个树分为左子树和右子树:
在这里插入图片描述
在左子树中,我们继续根据前序遍历(根左右)进行划分:

在这里插入图片描述
依次内推:将这个树不停的划分成:根,左子树,右子树。

我们的主问题是根左右,而子问题也是根左右,子问题的子问题的也是根左右。子问题是相同的。

例子二
我们复习一下快排:
在这里插入图片描述
找一个key,将数组从key位置划分为左右两个部分,让这两个左右部分排序。而让左右两个部分排序,又可以进行划分,在左右两个数组继续用Key进行划分:
在这里插入图片描述
依次内推:不停的划分,知道最后不停划分为两个元素后大小就很好比较。

这个例子我们也可以发现主问题是通过key将数组划分为两部分,而子问题也是通过key将数组划分为两部分,子问题的子问题也是通过key将数组划分为两部分。

通过这两个例子,我们想告诉递归的本质:
递归的本质其实就是重复的子问题,也就是说主问题可以划分成一个跟主问题相同的子问题
在这里插入图片描述

如何理解递归

那么如何理解递归?
这里给出两点:

  1. 递归展开
  2. 宏观看待递归的过程

想要理解递归,就要画一下递归的展开图,将递归通过展开图展开,会很明显看到递归相关细节:返回条件,如何递归

其次我们要宏观看待一个递归得到过程:
具体分一下几步:

  1. 不要在意递归的细节展开图
  2. 把递归的函数当成一个黑盒
  3. 相信这个黑盒一定能把这件事做好

就比如我们的二叉树后序遍历:

在这里插入图片描述
首先我们要通过根节点来进行遍历,黑盒装什么呢?
我们知道后序是:左->右->根
那么我们就坚信dfs(root->left)一定能帮我们实现进行左子树的遍历,dfs(root->right)一定能帮我们实现进行右子树的遍历
这就相当于是我们的黑盒。

但是还要注意一个细节:
为了防止进行死循环,我们要写一个出口(也就是返回条件)

怎样写好递归

有了上面的经验,怎样写好递归就很简单:

  1. 先找到相同子问题(这就是我们函数头的设计)
  2. 只关心某一个问题是如何来的(这就涉及到函数体的书写)
  3. 注意细节:递归函数出口防止死循环
    在这里插入图片描述

搜索

深度优先/宽度优先

首先要知道什么是深度优先,什么是宽度优先:
深度优先:深度优先就是一条道走到黑,我们也叫DFS,通常用递归实现。
在这里插入图片描述
跟二叉树遍历一样,从根开始,一直往下走,知道左子树最后一个节点走完不能再走了就往上走。

宽度优先:宽度就是一层一层的剥开,我们也叫BFS,通常借助队列实现。
在这里插入图片描述
就比如还是二叉树遍历,我们一层一层的进行遍历,将每一层遍历出来。

在这里插入图片描述
那么深度优先遍历和深度优先搜索又有什么区别呢?
其实遍历和搜索大致是一样的,记住一点:遍历知识形式,就比如二叉树遍历只是根据规则进行遍历,而搜索是遍历里面的值,因此也叫搜索。

关系图

其实搜索也叫暴搜,暴搜顾名思义就是暴力枚举一遍所有的情况。
在这里插入图片描述

拓展搜索

其实我们之前学过的全排列就是一个搜索问题。

以123三个数的全排列为例,我们高中就学过,要想枚举出全部的结果,用树状能很清晰的表达出来:
在这里插入图片描述
通过树状这样画出来就不会漏解的情况。

这棵树我们也把它叫做决策树。

回溯与剪枝

什么是回溯,什么是剪枝,其实他们两的本质也还是搜索!!!
回溯还是以二叉树遍历为例:

在这里插入图片描述
当遍历到左子树的最左节点,他的左子树为空,那么就要返回,而这个返回的过程就是回溯。

以这个迷宫为例子:

在这里插入图片描述
第一段红线走到尽头发现走不掉了,往回走的过程就是回溯。

根据暴搜原理,会一直往右走,走到尽头,向上走,走到尽头发现到头了,就往回走,然后往左走,往右走,依次内推。在这个过程中,有一段是没有必要走的路段(没有价值的路段),在本图中是画叉的路段,这个画叉的路段我们就可以舍去,舍去的过程就是剪枝。

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

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

相关文章

分享6个解决msvcp110.dll丢失的方法,全面解析msvcp110.dll文件

msvcp110.dll 是一个动态链接库 (DLL) 文件,属于 Microsoft Visual C 库的一部分,具体来说是 Microsoft Visual C 2012 版本的运行时组件。这个 DLL 文件包含了在 Windows 环境下运行用 C 编写的程序所必需的一些函数和资源。当一个应用程序是使用 Visua…

视频拉流推流技术梳理

概况 视频的整个流程主要分为推流和拉流 摄像头场景: 摄像头捕捉视频画面,推流到服务器,服务器分发到CDN, 客户端从CDN地址拉流,客户端进行播放 直播场景: 主播通过手机,电脑等客户端&…

G8-ACGAN理论

本文为🔗365天深度学习训练营 中的学习记录博客 原作者:K同学啊|接辅导、项目定制 我的环境: 1.语言:python3.7 2.编译器:pycharm 3.深度学习框架Pytorch 1.8.0cu111 一、对比分析 前面的文章介绍了CGAN&#xf…

java基础(4)注解,集合,

注解 什么是注解(Annotation)?注解是放在Java源码的类、方法、字段、参数前的一种特殊“注释” // this is a component: Resource("hello") public class Hello {Injectint n;PostConstructpublic void hello(Param String name…

经典文献阅读之--CamMap(基于SLAM地图对不共视相机进行外参标定)

0. 简介 由于多相机之间通常存在有限或无重叠的视场,因此在估计外参相机参数时面临着一定的挑战,为了解决这个问题,本文提出了CamMap:一种新颖的6自由度外参标定流程。根据三个操作规则,使一个多相机系统单独捕捉一些…

【Linux进程】进程状态(运行阻塞挂起)

目录 前言 1. 进程状态 2. 运行状态 3. 阻塞状态 4. 挂起状态 5. Linux中具体的状态 总结 前言 在Linux操作系统中,进程状态非常重要,它可以帮助我们了解进程在系统中的运行情况,从而更好地管理和优化系统资源,在Linux系统中&am…

【Python笔记-设计模式】迭代器模式

一、说明 迭代器模式是一种行为设计模式,让你能在不暴露集合底层表现形式(列表、栈和树等)的情况下遍历集合中所有的元素。 (一) 解决问题 遍历聚合对象中的元素,而不需要暴露该对象的内部表示 (二) 使用场景 需要对聚合对象…

SpringBoot实现短链跳转

目录 1.背景介绍 2.短链跳转的意义 3.SpringBoot中的代码实现 1.建议短链-长链的数据库表:t_url_map: 2.映射实体 3.Dao层实现 4.Service层实现 5.Controller层实现 3.结果测试 4.问题 1.背景介绍 短链跳转是一种通过将长链接转换为短链接的方式&…

南方电网的能源棋局上,蔚来换电扮演什么角色?

2 月 26 日,南网储能科技与蔚来能源签署协议,将充换电站、储能站、可调负载等聚合资源连接到虚拟电厂平台,推动换电站作为分布式储能在虚拟电厂项目上的应用。 蔚来换电站是国内首个智慧微电网型分布式换电设施,可透过换电订单预…

软考-系统集成项目管理中级-信息系统建设与设计

本章重点考点 1.信息系统的生命周期 信息系统建设的内容主要包括设备采购、系统集成、软件开发和运维服务等。信息系统的生命周期可以分为四个阶段:立项、开发、运维和消亡。 2.信息系统开发方法 信息系统常用的开发方法有结构化方法、原型法、面向对象方法等 1)结构化方法 …

AI智能分析网关V4:抽烟/打电话/玩手机行为AI算法及场景应用

抽烟、打电话、玩手机是人们在日常生活中常见的行为,但这些行为在某些场合下可能会带来安全风险。因此,对于这些行为的检测技术及应用就变得尤为重要。今天来给大家介绍一下TSINGSEE青犀AI智能分析网关V4抽烟/打电话/玩手机检测算法及其应用场景。 将监控…

java项目打包运行报异常:xxxxx-1.0-SNAPSHOT.jar中没有主清单属性

pom.xml中加入这段话即可 <build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId><version>2.4.4</version><executions><execution><…

安泰ATA-7050高压放大器在微流控细胞分选中的应用

微流控细胞分选是一种用于分离和鉴定生物样本中特定类型细胞的技术&#xff0c;其原理基于将生物细胞通过微通道进行操纵和区分。微流控细胞分选的原理主要基于流体力学、电气学、光学和热力学等多学科的交叉应用。通过设计具有特定尺寸和性质的微通道网络&#xff0c;可实现对…

RV1126芯片概述

RV1126芯片概述 前言1 主要特性2 详细参数 前言 1 主要特性 四核 ARM Cortex-A7 and RISC-V MCU250ms快速开机2.0Tops NPU14M ISP with 3帧 HDR支持3个摄像头同时输入4K H.264/H.265 视频编码和解码 2 详细参数

永磁同步电机无感FOC(龙伯格观测器)算法技术总结-仿真篇

文章目录 1、观测器的引入2、β轴向下的电机观测器数学模型3、β轴向下的转子点角度及速度观测4、Simulink仿真模型搭建4.1模型总览4.2 Luenberger观测器模块4.2.1 I_alpha观测4.2.2 I_beta观测4.2.3 e_alpha、e_beta观测4.2.4 锁相环 4.3 速度设定4.4 速度观测结果4.5 电角度观…

express+mysql+vue,从零搭建一个商城管理系统6--数据校验和登录

提示&#xff1a;学习express&#xff0c;搭建管理系统 文章目录 前言一、修改models/user.js二、修改routes下的user.js三、Api新建user/login接口四、删除数据库原有数据&#xff0c;添加新验证规则的用户四、用户登录总结 前言 需求&#xff1a;主要学习express&#xff0c;…

MacBook将iPad和iPhone备份到移动硬盘

#创作灵感# 一个是ICloud不够用&#xff0c;想备份到本地&#xff1b;然而本地存储不够用&#xff0c;增加容量巨贵&#xff0c;舍不得这个钱&#xff0c;所以就想着能不能备份到移动硬盘。刚好有个移动固态&#xff0c;所以就试了一下&#xff0c;还真可以。 #正文# 说一下逻…

《PyTorch深度学习实践》第八讲加载数据集

一、 1、DataSet 是抽象类&#xff0c;不能实例化对象&#xff0c;主要是用于构造我们的数据集 2、DataLoader 需要获取DataSet提供的索引[i]和len;用来帮助我们加载数据&#xff0c;比如说做shuffle(提高数据集的随机性)&#xff0c;batch_size,能拿出Mini-Batch进行训练。它…

Windows10环境下MongoDB安装配置

1. 下载对应MongoDB安装包 进入官网&#xff1a;MongoDB官网 如果不连接外网则在官网下载较慢&#xff0c;这里给出下载好的安装包&#xff0c;版本为4.2.25&#xff1a;百度网盘 选择你需要的版本&#xff0c;推荐选择Package的格式为zip&#xff08;解压即可&#xff09; Pa…

[VNCTF2024]-PWN:preinit解析(逆向花指令,绕过strcmp,函数修改,机器码)

查看保护&#xff1a; 查看ida&#xff1a; 这边其实看反汇编没啥大作用&#xff0c;需要自己动调。 但是前面的绕过strcmp还是要看一下的。 解题&#xff1a; 这里是用linux自带的产生随机数的文件urandom来产生一个随机密码&#xff0c;然后让我们输入密码&#xff0c;用st…