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

文章目录

  • 一. 名词解释
    • 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.rhkb.cn/news/216489.html

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

相关文章

git自动更新功能

确认权限 因为一般Linux系统网页用的www 或 www-data用户和用户组&#xff0c;所以要实现自动来去&#xff0c;首先要在www用户权限下生成ssh密钥&#xff0c;不然没有权限&#xff0c;其次就是&#xff0c;要把用root用户拉去的代码&#xff0c;批量改成www用户 1. 给www权…

Unity | 渡鸦避难所-2 | 搭建场景并添加碰撞器

1 规范项目结构 上期中在导入一系列的商店资源包后&#xff0c;Assets 目录已经变的混乱不堪 开发过程中&#xff0c;随着资源不断更新&#xff0c;遵循一定的项目结构和设计规范是非常必要的。这可以增加项目的可读性、维护性、扩展性以及提高团队协作效率 这里先做下简单的…

最新鸿蒙HarmonyOS4.0开发登陆的界面1

下载deveco-studio 说明一下&#xff0c;本人只是学习中&#xff0c;现在只是拿着vue及uniapp的经验在一点一点的折腾&#xff0c;不过现在看来&#xff0c;鸿蒙入门并不是很难。也许是自己没有深入下去。 https://developer.harmonyos.com/cn/develop/deveco-studio#download…

Ubuntu 20.04 安装 mysql8 LTS

Ubuntu 20.04 安装 mysql8 LTS sudo apt-get update sudo apt-get install mysql-server -y mysql --version mysql Ver 8.0.35-0ubuntu0.20.04.1 for Linux on x86_64 ((Ubuntu)) Ubuntu20.04 是自带了 MySQL8. 几版本的&#xff0c;低于 20.04 则默认安装是 MySQL5.7.33…

基于Java8构建Docke镜像

基于Java8构建Docke镜像 搜索java8安装包 docker search java8 --no-trunc &#xff0c; --no-trunc展开描述信息 选择拉取 docker pull docker.io/mykro/java8-jre&#xff0c;为了减少磁盘占用&#xff0c;选择jre版本基础镜像 在宿主机创建文件夹iot&#xff0c;并把所需…

IDEA中,光标移动快捷键(Shift + 滚轮前后滚动:当前文件的横向滚动轴滚动。)

除此之外&#xff0c;其他常用的光标移动快捷键包括&#xff1a; Shift 滚轮前后滚动&#xff1a;当前文件的横向滚动轴滚动。Shiftenter&#xff1a;快速将鼠标移动到下一行。Ctrl ]&#xff1a;移动光标到当前所在代码的花括号结束位置。Ctrl 左方向键&#xff1a;光标跳转…

VisualSVN Server的安装全过程

目录 背景: 安装过程&#xff1a; 步骤1&#xff1a; 步骤2&#xff1a; 步骤3&#xff1a; 步骤4&#xff1a; 步骤5&#xff1a; 安装出现的bug&#xff1a; 问题: 解决办法: 总结: 背景: VisualSVN Server 是一款免费的 SVN (Subversion) 服务器软件&#xff0c…

大数据技术8:StarRocks极速全场景MPP数据库

前言&#xff1a;StarRocks原名DorisDB&#xff0c;是新一代极速全场景MPP数据库。StarRocks 是 Apache Doris 的 Fork 版本。StarRocks 连接的多种源。一是通过这个 CDC 或者说通过这个 ETL 的方式去灌到这个 StarRocks 里面&#xff1b;二是还可以去直接的和这些老的 kafka 或…

【报错栏】(vue)Module not found: Error: Can‘t resolve ‘element-ui‘ in xxx

Module not found: Error: Cant resolve element-ui in xxx 报错原因是&#xff1a; 未安装 element-ui 依赖 解决&#xff1a; npm install element-ui 运行

h2-database 安装部署学习

1&#xff0c;下载jar 包 Archive Downloads 进入到下载的包的位置&#xff1a; cd E:\IDE\Java\jre\lib 2&#xff0c;参考以下说明进行数据库创建&#xff1a; Tutorial 执行如下 可以进行创建默认的数据库 设置用户密码 E:\IDE\Java\jre\lib> java -cp h2-2.2.224.…

体系化学习运筹学基础算法的实践和总结

文章目录 引言目标设计目标实践文章汇总经验总结一则预告 引言 眨眼间已经12月了&#xff0c;眼看着2023年马上要过完了。 女朋友最近总说&#xff0c;工作以后感觉时间过的好快。事实上&#xff0c;我也是这么认为的。年纪越大&#xff0c;越会担心35岁危机的降临。所以&…

波奇学Linux:环境变量,本地变量和内建命令

Windows下的环境变量 echo $PATH 查看指令搜索命令路径 在bash命令行输入的指令&#xff0c;系统根据PATH中的路径查询。 增加PATH指令 $PATH等于上面的路径 :表示不同路径分割符 /home/boki/lesson13代表新的路径 相当于一个赋值语句。 相当于指令&#xff0c;可以直接使用…

K8s中pod詳解

目录 Yaml语法解析 Pod pod是如何被创建的 1.创建一个pod 2.创建一个多容器pod 进入容器 3.配置节点标签 4.Pod容器的交互 4.1创建pod&#xff0c;并做本地解析 4.2pod共享进程 4.3pod共享宿主机namespace 5.钩子函数lifecycle 基础指令 # 查看对应资源: 状态 $ kubectl…

数据结构二维数组计算题,以行为主?以列为主?

1.假设以行序为主序存储二维数组Aarray[1..100,1..100]&#xff0c;设每个数据元素占2个存储单元&#xff0c;基地址为10&#xff0c;则LOC[5,5]&#xff08; &#xff09;。 A&#xff0e;808 B&#xff0e;818 C&#xff0e;1010 D&…

〖大前端 - 基础入门三大核心之JS篇(53)〗- 构造函数与类

说明&#xff1a;该文属于 大前端全栈架构白宝书专栏&#xff0c;目前阶段免费&#xff0c;如需要项目实战或者是体系化资源&#xff0c;文末名片加V&#xff01;作者&#xff1a;哈哥撩编程&#xff0c;十余年工作经验, 从事过全栈研发、产品经理等工作&#xff0c;目前在公司…

ffmpeg编解码——数据包(packet)概念(如何正确处理数据包中的显示时间戳pts与解码时间戳dts关系?)

文章目录 FFmpeg编解码——数据包&#xff08;Packet&#xff09;概念1. 数据包&#xff08;Packet&#xff09;简介2. 数据包&#xff08;Packet&#xff09;在FFmpeg中的应用2.1 从媒体文件读取数据包2.2 向媒体文件写入数据包 3. 数据包&#xff08;Packet&#xff09;相关问…

推荐一款好用的包含表格识别的OCR网站

在当今数字化的时代&#xff0c;文字和表格识别已经成为了许多行业的关键技术。无论是处理大量的纸质文档&#xff0c;还是从网络上收集数据&#xff0c;OCR&#xff08;光学字符识别&#xff09;技术都扮演着重要的角色。然而&#xff0c;对于许多用户来说&#xff0c;OCR软件…

【代码随想录算法训练营-第六天】【哈希表】242,349,202,1

242.有效的字母异位词 第一遍 思考 比较简单&#xff0c;用数组就能实现了 class Solution {public boolean isAnagram(String s, String t) {int[] checkListi new int[256];int[] checkListj new int[256];for (int i 0; i < s.length(); i) {char checkChar s.ch…

linux ksm实现与代码简述

KSM 全称是 Kernel Samepage Merging&#xff0c;表示相同的物理页只映射一份拷贝。 原理 在ksm初始化时&#xff08;ksm_init&#xff09;&#xff0c;注册了一个ksm_scan_thread线程&#xff0c;这个线程的核心入口是ksm_do_scan。当对一个进程第一次通过madvice(MADV_MERGE…

C# WPF上位机开发(会员管理软件)

【 声明&#xff1a;版权所有&#xff0c;欢迎转载&#xff0c;请勿用于商业用途。 联系信箱&#xff1a;feixiaoxing 163.com】 好多同学都认为上位机只是纯软件开发&#xff0c;不涉及到硬件设备&#xff0c;比如听听音乐、看看电影、写写小的应用等等。如果是消费电子&#…