【算法】递归、搜索与回溯算法

文章目录

  • 一. 名词解释
    • 1. 递归
      • 1.1 什么是递归?
      • 1.2 为什么会用到递归?
      • 1.3 如何理解递归?
      • 1.4 如何写好一个递归?
    • 2. 遍历和搜索
    • 3. 回溯和剪枝
  • 二. 递归系列专题
    • 1. 汉诺塔问题
    • 2. 合并两个有序链表
    • 3. 反转链表
    • 4. 两两交换链表中的节点
    • 5. pow(x, n) - 快速幂

一. 名词解释

1. 递归

1.1 什么是递归?

递归就是函数自己调用自己

1.2 为什么会用到递归?

本质:我们在解决主问题时,会遇到和主问题相同的子问题,而子问题和主问题的解决方式一样,所以必定会出现函数自己调用自己(即递归)的情况。
在这里插入图片描述

递归示例一:二叉树前序遍历
在这里插入图片描述

递归示例二:快速排序
在这里插入图片描述

递归示例三:归并排序
在这里插入图片描述

1.3 如何理解递归?

实际处理递归问题时,如果能够宏观地看待递归,那么代码就会特别好写。其实做多了一些二叉树类的递归题目后,我们大抵就能够宏观地看待和理解递归了,可以总结出以下三个方面:

  • 不要在意递归的细节展开图,这会让你做题目时非常痛苦
  • 把递归的函数当成一个黑盒,我们只用传入参数,然后等待它返回给我们结果
  • 相信这个黑盒一定能完成任务

举例:二叉树的后序遍历
在这里插入图片描述

1.4 如何写好一个递归?

  1. 先找到相同的子问题(可以帮助我们完成函数头的设计)
  2. 只关心某一个子问题是如何解决的(有助于我们完成函数体的书写)
  3. 注意一下递归函数的出口(考虑哪些情况下,递归不能再进行下去)

2. 遍历和搜索

在这里插入图片描述

3. 回溯和剪枝

下面我们通过一个走迷宫的例子来解释回溯和剪枝:
在这里插入图片描述

我们在看题解的时候,经常看到有些人用深搜,有些人用广搜,还有些人用回溯;其实回溯就是深度优先搜索。

二. 递归系列专题


1. 汉诺塔问题


题目链接

算法原理

在这里插入图片描述

代码编写

class Solution 
{
private:
    void dfs(vector<int>& A, vector<int>& B, vector<int>& C, int n) 
    {
        // 0、递归出口:只剩一个盘子的话就直接移动
        if(n == 1) 
        {
            C.push_back(A.back());
            A.pop_back();
            return;
        }
        // 1. 先把 a 柱上 n - 1 个盘子借助 c 移动到 b 柱
        dfs(A, C, B, n - 1);
        // 2. 再把 a 柱剩下的一个盘子直接移动到 c 柱
        C.push_back(A.back());
        A.pop_back();
        // 3. 最后再把 b 柱上的 n - 1 个盘子借助 a 移动到 c 柱
        dfs(B, A, C, n - 1);
    }

public:
    void hanota(vector<int>& A, vector<int>& B, vector<int>& C) 
    {
        dfs(A, B, C, A.size());
    }
};

2. 合并两个有序链表


题目链接

算法原理
在这里插入图片描述

代码编写

class Solution 
{
public:
    ListNode* mergeTwoLists(ListNode* list1, ListNode* list2) 
    {
        // 0、特殊情况处理
        if(!list1) return list2;
        if(!list2) return list1;
        // 1、比较第一个节点值的大小
        // 2、记录较小节点,继续合并后续链表
        // 3、返回合并后链表的头节点
        if(list1->val < list2->val) 
        {
            list1->next = mergeTwoLists(list1->next, list2);
            return list1;
        }
        else
        {
            list2->next = mergeTwoLists(list1, list2->next);
            return list2;
        }
    }
};

3. 反转链表


题目链接

算法原理
在这里插入图片描述

代码编写

class Solution 
{
public:
    ListNode* reverseList(ListNode* head) 
    {
        // 0、特殊情况处理
        if(!head || !head->next) return head;
        // 1、先逆置后面的链表
        ListNode* ans = reverseList(head->next);
        // 2、让当前节点添加到逆置后的链表
        head->next->next = head;
        head->next = nullptr;
        // 3、返回值
        return ans;
    }
};

4. 两两交换链表中的节点


题目链接

算法原理
在这里插入图片描述

代码编写

class Solution 
{
public:
    ListNode* swapPairs(ListNode* head) 
    {
        // 0、特殊情况处理
        if(!head || !head->next) return head;
        // 1、先处理后部分链表两两交换
        auto tmp = swapPairs(head->next->next);
        // 2、对当前两个节点两两交换
        auto ans = head->next;
        head->next->next = head;
        head->next = tmp;
        // 3、返回值
        return ans;
    }
};

5. pow(x, n) - 快速幂


题目链接

算法原理
在这里插入图片描述

代码编写

class Solution 
{
private:
    double Pow(double x, long long n) 
    {
        if(!n) return 1;
        double tmp = Pow(x, n/2);
        return n % 2 == 1 ? tmp * tmp * x : tmp * tmp;
    }

public:
    double myPow(double x, int n) 
    {
        return n < 0 ? 1.0 / Pow(x, (long long)n * -1.0) : Pow(x, n);
    }
};

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

关于Anaconda的安装和环境部署(此章专为新手制定)

目录 Anaconda简介 一、软件下载&#xff08;地址&#x1f447;&#xff09; 2&#xff1a;点击下载 3&#xff1a;版本选择&#xff1a; 4&#xff1a;Anaconda的安装包就下载完成了 2&#xff1a;恭喜你&#xff0c;看到这里已经完成安装了 三、部署环境 1&#xff1…

什么是 AWS IAM?如何使用 IAM 数据库身份验证连接到 Amazon RDS(上)

驾驭云服务的安全环境可能很复杂&#xff0c;但 AWS IAM 为安全访问管理提供了强大的框架。在本文中&#xff0c;我们将探讨什么是 AWS Identity and Access Management (IAM) 以及它如何增强安全性。我们还将提供有关使用 IAM 连接到 Amazon Relational Database Service (RDS…

C++类模板分文件编写

问题&#xff1a; 类模板中成员函数创建时机是在调用阶段&#xff0c;导致分文件编写时链接不到 解决&#xff1a; 解决方式最常用的&#xff1a;将声明和实现写到同一个文件&#xff0c;并更改后缀名为.hpp&#xff0c;hpp是约定的名称&#xff0c;并不是强制的

Windows/Linux混合刻录后,Windows显示空白盘解决思路

概述 因为工作环境问题&#xff0c;需要在Windows和Linux之间来回光盘刻录&#xff0c;没有多余光盘的时候经常多次使用&#xff0c;同一光盘在Windows刻录文件到Linux&#xff0c;然后从Linux刻录文件到Windows&#xff0c;Windows用“类似U盘”格式化的光盘&#xff0c;在Wi…

洛谷 P8802 [蓝桥杯 2022 国 B] 出差

文章目录 [蓝桥杯 2022 国 B] 出差题目链接题目描述输入格式输出格式样例 #1样例输入 #1样例输出 #1 提示 思路解析CODE [蓝桥杯 2022 国 B] 出差 题目链接 https://www.luogu.com.cn/problem/P8802 题目描述 A \mathrm{A} A 国有 N N N 个城市&#xff0c;编号为 1 … N …

三天精通Selenium Web 自动化 - Selenium(Java)环境搭建

1 下载JDK JDK下载地址&#xff1a;http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html 2 安装和配置JDK 安装目录尽量不要有空格 D:\Java\jdk1.8.0_91; D:\Java\jre8设置环境变量&#xff1a; “我的电脑”->右键->“属性”->…

LeetCode刷题日志-73矩阵置零

思路一&#xff1a; 用一个同样大小的矩阵记录0的位置&#xff0c;然后遍历矩阵置0&#xff0c; 空间复杂度为O&#xff08;mn&#xff09; class Solution {public void setZeroes(int[][] matrix) {int [][] matrix_new new int[matrix.length][matrix[0].length];for(int …

postgresql自带指令命令系列三

目录 简介 bin目录 28.pg_verifybackup 29.pg_waldump 30.postgres 31.postmaster -> postgres 32.psql 33.reindexdb 34.vacuumdb 35.vacuumlo 总结&#xff1a; 简介 在安装postgresql数据库的时候会需要设置一个关于postgresql数据库的PATH变量 export PATH/…

1845_emacs中一个中文乱码问题分析解决

Grey 全部学习内容汇总&#xff1a;GitHub - GreyZhang/editors_skills: Summary for some common editor skills I used. 1845_emacs中一个中文乱码问题分析解决 曾经有一次放弃过我自己的emacs配置&#xff0c;一个原因就是中文的支持。感觉我的配置跟其他人的配置显得有些…

优雅玩转实验室服务器(一)登录服务器

这篇文章更加偏向于使用python程序进行研究的朋友们 原料 Windows主机实验室Linux服务器&#xff08;可以访问互联网&#xff09;一点点耐心 step.0 windows terminal is all you need 别跟我说什么putty&#xff0c;什么winscp&#xff0c;我就是单推Win11自带的软件——win…

deepface:实现人脸的识别和分析

deepface介绍 deepface能够实现的功能 人脸检测&#xff1a;deepface 可以在图像中检测出人脸的位置&#xff0c;为后续的人脸识别任务提供基础。 人脸对齐&#xff1a;为了提高识别准确性&#xff0c;deepface 会将检测到的人脸进行对齐操作&#xff0c;消除姿态、光照和表…

Python 进阶(十六):二进制和ASCII码的转换(binascii 模块)

大家好&#xff0c;我是水滴~~ 本文详细介绍了Python中的binascii模块及其使用方法。通过binascii模块&#xff0c;我们可以方便地进行二进制和ASCII字符串之间的转换操作。文章中包含大量的示例代码&#xff0c;希望能够帮助新手同学快速入门。 《Python入门核心技术》专栏总…

【unity】【WebRTC】从0开始创建一个Unity远程媒体流app-设置输入设备

【项目源码】 包括本篇需要的脚本都打包在项目源码中,可以通过下面链接下载: 【背景】 目前我们能投射到远端浏览器(或者任何其它Peer)的媒体流只有默认的MainCamera画面,其实我们还可以通过配置输入来传输操作输入信息,比如键鼠等。 【追加input processing组件】 …

在AWS Lambda中使用FFmpeg处理m3u8视频流

大纲 1 部署有FFmpeg功能的Lambda环境1.1 部署层1.2 部署代码1.2.1 FFmpeg指令1.2.2 代码 2 配置Lambda角色权限2.1 选择角色类型2.2 设置权限2.3 保存角色2.4 绑定角色 参考文献 在直播里领域&#xff0c;我们经常需要对视频流进行处理。FFmpeg则是该领域中处理的利器。这篇文…

Spring 面向切面编程(AOP)

一、aop介绍 &#xff08;一&#xff09;前言 一般的后端开发流程是纵向开发&#xff0c;就是controller&#xff08;控制层&#xff09;->service&#xff08;业务层&#xff09;->mapper&#xff08;数据持久层&#xff09;&#xff0c;Spring采用动态代理技术可以在…

关于mars3d通过zIndex参数实现控制图层层级叠加效果说明

问题&#xff1a; 1.项目中使用了GraphicLayer、GeoJSONLayer、ArcGISLayer&#xff0c;期望mars3d能够提供方法进行设置每个图层的zindex顺序 解决方案&#xff1a; 1.首先在mars3d的开发教程中查询三个Layer属于的图层类型&#xff0c;GraphicLayer、GeoJSONLayer均属于矢…

鸿蒙系统最近删除文件夹的路径

鸿蒙手机上删除文件&#xff0c;会将文件移动到类似回收站的路径下&#xff0c;如何找到这个路径&#xff1f; 先找用文件管理器找到一个文件 比如aaa.jpg &#xff0c;这时在调试的shell下面运行 find . -name aaaa.jpg 得到如下 这时再删除该文件 再次运行 find . -name a…

单片机——通信协议(FPGA+c语言应用之iic篇)

一.I2C的功能特点 &#xff08;1&#xff09;功能包括&#xff1a; 1.只需要两条总线&#xff1b; 2.没有严格的波特率要求&#xff0c;例如使用RS232&#xff0c;主设备生成总线时钟&#xff1b; 3.所有组件之间都存在简单的主/从关系&#xff0c;连接到总线的每个设备均可通…

【PTA刷题】 求子串(代码+详解)

【PTA刷题】 求子串(代码详解) 题目 请编写函数&#xff0c;求子串。 函数原型 char* StrMid(char *dst, const char *src, int idx, int len);说明&#xff1a;函数取源串 src 下标 idx 处开始的 len 个字符&#xff0c;保存到目的串 dst 中&#xff0c;函数值为 dst。若 len…

BERT大模型:英语NLP的里程碑

BERT的诞生与重要性 BERT&#xff08;Bidirectional Encoder Representations from Transformers&#xff09;大模型标志着自然语言处理&#xff08;NLP&#xff09;领域的一个重要转折点。作为首个利用掩蔽语言模型&#xff08;MLM&#xff09;在英语语言上进行预训练的模型&…
最新文章