当前位置: 首页 > news >正文

【递归、搜索与回溯算法】第一节.初识递归、搜索与回溯算法

作者简介:大家好,我是未央;

博客首页:未央.303

系列专栏:递归、搜索与回溯算法

每日一句:人的一生,可以有所作为的时机只有一次,那就是现在!!!!!

文章目录

前言

一、递归算法

1.1 什么是递归?

1.2 为什么会用到递归?

1.3 如何理解递归?

1.4 如何写好一个递归?

二、搜索算法

2.1 深度优先遍历vs深度优先搜索

2.2 宽度优先遍历vs宽度优先搜索

2.3 扩展搜索问题 

三、回溯算法

总结



前言

今天我们将进入到递归,搜索,回溯算法,这些算法在我们笔试中非常重要,必须要熟练掌握,本节内容主要带着认识一下这些算法,了解其本质,后面会有很多例题来巩固这些算法!!!!


一、递归算法

1.1 什么是递归?

我们要学会递归算法的使用,首先要了解它是什么,才能更好的掌握和使用它。

简而言之,递归:函数自己调用自己的情况;直到碰到终止条件,返回结果的过程。


递归可以看作两个过程,分别是递和归。

递就是原问题把要计算的结果传给子问题;

归则是子问题求出结果后,把结果层层返回原问题的过程。


1.2 为什么会用到递归?

递归的本质:

主问题可以推出与主问题相同的子问题;

子问题又可以继续推出与子问题相同的子子问题;


实例图示说明:

(1)二叉树的遍历:

(2)快速排序算法

(3)归并排序算法


1.3 如何理解递归?

第一步:递归展开细节图;

归并排序举例:

递归展开图(int arr[] = { 7,5,6,3,9,8,2,1,4,5 };)


第二步:二叉树的递归;

二叉树递归举例:

先简单的定义一个 二叉树;

像这样的二叉树: 


第三步:宏观看待递归过程(重要)

(1)不要在意递归的细节展开图;

(2)把递归当成一个黑盒;

(3)相信这个黑盒一定能完成这个任务;


1.4 如何写好一个递归?

第一步:

先找一下是否有和主问题相同的子问题!!!!!----->  关系到函数头的设计;


第二步:

只需要关心某一个子问题是如何解决即可!!!!-----> 关系到函数体的书写;


第三步:

最后再注意一下递归函数的出口即可;


代码示例说明:

(1)二叉树的递归:

代码实现:

//二叉树的后续遍历
void dfs(TreeNode* root){//递归的返回条件
if(root == null)
return;//先递归遍历左子树
dfs(root.left);
//再递归遍历右子树
dfs(root.right);
//最后遍历根结点
printf(root.value);}

(2)归并排序:

代码实现:

void merge(nums,int left,int right){
//细节:出口;
if(left >= right){int mid = (left+right)/2;
merge(nums,left,mid);
merge(nums,mid+1,right);
//合并两个有序数组
}

二、搜索算法

2.1 深度优先遍历vs深度优先搜索

深度优先遍历(深度优先搜索):一条路走到黑,走到不能继续走的时候就返回;

两者实际是一样的概念;而不同的是:

遍历是形式;搜索是目的;

图示说明:


2.2 宽度优先遍历vs宽度优先搜索

宽度优先遍历(深度优先搜索):又叫层次遍历从上往下对每一层依次访问,在每一层中,从左往右(也可以从右往左)访问结点,访问完一层就进入下一层,直到没有结点可以访问为止

两者实际是一样的概念;而不同的是:

遍历是形式;搜索是目的;


图示说明:


2.3 扩展搜索问题 

搜索方式,不仅仅局限于二叉树,图类等;还可以对于一些全排列,如果列举问题能用决策树的图示表示出来,依然可以用搜索来解决问题;


三、回溯算法

回溯算法定义:

回溯算法也叫试探法,它是一种系统地搜索问题的解的方法。一个典型的应用是走迷宫问题,当我们走一个迷宫时,如果无路可走了,那么我们就可以退一步,再在其他的路上尝试一步,如果还是无路可走,那么就再退一步,尝试新的路,直到走到终点或者退回到原点。


回溯的本质回溯的本质就是深搜;

图示说明:

总结

相关文章:

【递归、搜索与回溯算法】第一节.初识递归、搜索与回溯算法

作者简介:大家好,我是未央; 博客首页:未央.303 系列专栏:递归、搜索与回溯算法 每日一句:人的一生,可以有所作为的时机只有一次,那就是现在!!!&am…...

第十二届蓝桥杯模拟赛第一期

A填空题 问题描述 如果整数a是整数b的整数倍,则称b是a的约数。 请问,有多少个正整数是2020的约数。 答案提交 这是一道结果填空的题,你只需要算出结果后提交即可。本题的结果为一个整数,在提交答案时只填写这个整数&#xff0…...

【生成对抗网络】

生成对抗网络(Generative Adversarial Networks,简称GANs)是深度学习领域的一种创新结构,由Ian Goodfellow在2014年首次提出。GANs包括两个深度神经网络——一个生成器和一个判别器,它们通常以对抗的方式进行训练。 以…...

Redis性能滑坡:哈希表碰撞的不速之客【redis第二部分】

Redis性能滑坡:哈希表碰撞的不速之客 前言第一部分:Redis哈希表简介第二部分:哈希表冲突原因第三部分:Redis哈希函数第四部分:哈希表冲突的性能影响第五部分:解决冲突策略第六部分:redis是如何解…...

科技与教育的盛宴——探讨监控易在82届教装展的新机遇

在第82届中国教育装备展示会这个融合了科技与教育的盛宴上,监控易将展现其最新的教育信息化解决方案和技术创新成果。这不仅是一次产品的展示,更是一次理念、技术与需求的交流和碰撞。在这里,我们将一同探讨在科技日新月异的今天,…...

Bazzite:专为 Steam Deck 和 PC 上的 Linux 游戏打造的发行版

导读对于一个专为 Linux 游戏定制的发行版,你是否感兴趣呢?如果答案是肯定的,那么我们为你准备了绝佳选择。 Bazzite 是一个新推出的基于 Fedora 的发行版,它是为 Linux 桌面上的游戏,以及越来越火热的 Steam Deck 定…...

【MySQL】数据库数据类型

文章目录 1. 整体概要2. 数值类型(有符号) tinyint 创建表(无符号) tinyint 创建表bit类型float 类型(无符号)floatdecimal 3. 二进制类型char类型varchar类型 4. 日期时间日期时间类型 5. string 类型enum类型和set类型enum类型和set类型的查找在枚举中的查找在set中的查找 1.…...

计算机组成原理 new07 真值和机器数 无符号整数 定点整数 定点小数 $\color{red}{Δ}$

文章目录 真值和机器数 无符号整数无符号整数的定义无符号整数的特征无符号整数的表示范围无符号整数的加法无符号数的减法 有符号整数(定点整数)有符号整数的定义原码原码的特点反码反码的特点补码补码的特点快速求解n位负数补码的方法为什么补码能够多表示一个范围(重点)变形…...

基于SSM的文化培训学校网站的设计与实现

末尾获取源码 开发语言:Java Java开发工具:JDK1.8 后端框架:SSM 前端:Vue 数据库:MySQL5.7和Navicat管理工具结合 服务器:Tomcat8.5 开发软件:IDEA / Eclipse 是否Maven项目:是 目录…...

gitee-git使用

克隆gitee某代码仓库某分支流程 1.克隆远程gitee仓库某分支到本地 2.如果克隆gitee仓库是私有的系统会弹出弹框让你输入gitee的账户和密码 3.克隆远程分支完成 git所需命令 克隆远程仓库到本地 git clone 仓库URLgit克隆远程分支到本地 git clone -b 分支名 仓库URLgit 拉…...

欧拉图(Euler Graph)

这种「一笔画」问题与欧拉图或者半欧拉图有着紧密的联系,下面给出定义: 通过图中所有边恰好一次且行遍所有顶点的通路称为 欧拉通路; 通过图中所有边恰好一次且行遍所有顶点的回路称为 欧拉回路; 具有欧拉回路的无向图称为 欧拉图; 具有欧拉通路但不具有欧拉回路的无向图…...

【安全体系架构】——零信任网络架构

什么是零信任网络架构? 零信任网络架构是一种网络和信息安全模型,它将传统的信任模型颠覆,不再信任内部或外部用户、设备或网络。相反,它将每个访问请求都视为不受信任,要求对每个用户、设备和流量都进行认证和授权&a…...

mybatis动态sql一对多查询

在数据库设计中,一对多关系是非常多的,例如消息通知和附件,一个消息通知中往往会包含多个附件,这种情况下使用mybatis动态sql可以很方便的查询出来。 1、数据库设计 消息表:sys_message CREATE TABLE sys_message (i…...

Leetcode.2316 统计无向图中无法互相到达点对数

题目链接 Leetcode.2316 统计无向图中无法互相到达点对数 rating : 1604 题目描述 给你一个整数 n n n ,表示一张 无向图 中有 n n n 个节点,编号为 0 0 0 到 n − 1 n - 1 n−1 。同时给你一个二维整数数组 e d g e s edges edges ,其…...

介绍机器学习中CatBoost工具的详细使用指南

在机器学习的动态世界中,Python 是创新背后的驱动力,专业人士必须使用正确的工具。CatBoost 就是这样一个工具,以其卓越的速度和准确性悄然改变了该领域。在本指南中,我们将深入研究 Python 3 中的 CatBoost,涵盖基础知识、高级技术和实际示例,包括使用示例数据集和绘图进…...

操作系统【OS】线程与进程的比较

进程 线程 是什么的单位? 是资源分配的基本单位 是调度的基本单位 不能共享什么? 不能共享虚拟地址空间 不能共享栈指针 可以共享什么? 拥有一个完整的资源平台 每个进程都有独立的地址空间和资源 除了共享全局变量,不允许其他进程访问 某进程中的线程…...

在Mac上使用安卓桌面模式

在安装Homeblew的基础上 替换国内源 export HOMEBREW_API_DOMAIN"https://mirrors.tuna.tsinghua.edu.cn/homebrew-bottles/api" export HOMEBREW_BREW_GIT_REMOTE"https://mirrors.tuna.tsinghua.edu.cn/git/homebrew/brew.git" brew update 安装Scrcpy …...

YOLO目标检测——人脸口罩佩戴数据集【(含对应voc、coco和yolo三种格式标签】

实际项目应用:公共场所监控场景下的大密度人群检测是否佩戴口罩,以及戴口罩的人证比对(安检刷脸不用摘口罩)、手机解锁、刷脸考勤等身份认证场景。数据集说明:人脸口罩佩戴检测数据集,真实场景的高质量图片…...

mongodb如何多表查询,如同时查询店铺以及里面对应的商品

多表查询场景介绍 一种很常见的场景,比如电商首页中,需要同时展示最近比较火热的店铺,以及直接展示店铺里对应的商品。或者用户下单之后购物车里可以看到所选的商品以及对应的店铺。如果不知道如何用mongodb自带的查询语句快速查询的话&#…...

Linux环境修改服务器时间和网络时间保持一致

目录 介绍UTC和CST 修改时区 修改时间 介绍UTC和CST UTC是协调世界时,是全球统一的时间标准。UTC的时间是基于原子钟计算的,以秒为单位,不受夏令时等影响。世界各地都可以通过UTC来同步时间。 CST是中央标准时间,相当于UTC-6…...

R语言数据处理:别再只会用==了,试试grep()和grepl()精准匹配字符串

R语言数据处理:别再只会用了,试试grep()和grepl()精准匹配字符串 你是否曾经在R语言中处理文本数据时,被简单的等值匹配()折磨得焦头烂额?想象一下这样的场景:你手头有一份包含上万条商品描述的…...

【LaTeX】表格标题与表格间距调整:从基础命令到实战技巧

1. LaTeX表格排版的核心痛点 第一次用LaTeX排表格时,我盯着PDF输出文件皱起了眉头——表格标题几乎要贴到表格内容上,活像被压缩的三明治。这种"亲密无间"的排版在学术论文里特别扎眼,审稿人可能觉得我们连基础排版都不重视。表格标…...

Python3 实例

Python3 实例 引言 Python3 作为一种广泛使用的编程语言,以其简洁明了的语法和强大的库支持在多个领域得到了广泛应用。本文将通过实例展示 Python3 在不同场景下的应用,帮助读者更好地理解和掌握 Python3 的使用。 Python3 简介 Python3 是 Python 编程…...

3分钟从B站视频到文字稿:bili2text终极使用指南

3分钟从B站视频到文字稿:bili2text终极使用指南 【免费下载链接】bili2text Bilibili视频转文字,一步到位,输入链接即可使用 项目地址: https://gitcode.com/gh_mirrors/bi/bili2text 想要快速将Bilibili视频内容转为可编辑的文字稿吗…...

JetBrains IDE试用期重置器:跨平台评估信息清理架构设计

JetBrains IDE试用期重置器:跨平台评估信息清理架构设计 【免费下载链接】ide-eval-resetter 项目地址: https://gitcode.com/gh_mirrors/id/ide-eval-resetter ide-eval-resetter是一款专门针对JetBrains IDE系列产品的试用期重置工具,采用智能…...

Qianfan-OCR代码实例:基于requests的带Layout分析OCR封装类

Qianfan-OCR代码实例:基于requests的带Layout分析OCR封装类 1. 项目概述 Qianfan-OCR是百度千帆推出的开源端到端文档智能多模态模型,基于4B参数的Qwen3-4B语言模型构建。这个多模态视觉语言模型(VLM)采用Apache 2.0协议,完全开源且可商用&…...

Blazor组件库选型生死局(2026版):MatBlazor停更、Radzen商业闭源、MudBlazor v8.0深度兼容性测试结果与开源替代矩阵

第一章:Blazor 2026现代Web开发全景图谱与生态演进逻辑Blazor 在 2026 年已全面融入 Web 开发核心基础设施,其技术定位从“C# 前端替代方案”跃迁为“全栈统一编译时契约驱动框架”。借助 .NET 10 的 AOT 编译增强、WASM 运行时深度优化及浏览器原生能力…...

【2026年华为暑期实习(AI)-4月22日-第二题- 统计二叉树中“平衡路径”的数量】(题目+思路+JavaC++Python解析+在线测试)

题目内容 定义二叉树的平衡路径需同时满足以下 333 个条件: 路径从任意节点出发,仅能向下延伸(只能向左/右子节点,不可向上回溯)。 路径上所有节点的和相加为 000。 路径长度(包含的节点个数)至少为 22...

Node.js 最新实战:从环境搭建到生产部署完整记录

一、前言 Node.js 最新实战:从环境搭建到生产部署完整记录是现代 DevOps 实践中的核心环节。本文从实际生产场景出发,给出完整可落地的方案。 二、基础配置 2.1 Dockerfile 最佳实践 # 多阶段构建:减少镜像体积,加快构建速度 F…...

Phi-4-mini-flash-reasoning惊艳效果展示:同一题Temperature=0.1 vs 0.6对比

Phi-4-mini-flash-reasoning惊艳效果展示:同一题Temperature0.1 vs 0.6对比 1. 模型简介 Phi-4-mini-flash-reasoning是一款专注于文本推理的轻量级模型,特别擅长处理需要逐步分析和逻辑推导的任务。这个模型就像一位思维缜密的数学老师,能…...