leetcode分类刷题:如何更好地理解递归

news2025/1/15 6:58:39

文章目录

  • 概念含义
  • 递归三要素
  • 递归算法的编程模型
  • 递归问题分类
  • 递归vs循环(迭代)
  • 参考文献

参考知乎上递归下的一个高赞回答,觉得写的非常好,挑选有助于自己理解的内容进行简单总结。

概念含义

1、递归(Recursion)是指在函数的定义中调用函数自身的方法;其包含了两个意思:,这正是递归思想的精华所在。
2、有去(递去)有回(归来)—— :递归问题必须可以分解为若干个规模较小、与原问题形式相同的子问题,这些子问题可以用相同的解题思路来解决;:若干个子问题会有一个明确的临界点,从这个临界点开始,原路返回到原点,原问题解决。
递归过程示意图
递归过程示意图

递归三要素

1、递归终止条件:递归有一个明确的临界点,一旦到达这个临界点,就不用继续递去而是开始归来;换句话说,该临界点就是一种简单情境,可以防止无限递归。
2、递归终止时的处理办法:在递归临界点的简单情境下,应该直接给出问题的答案
3、提取重复的逻辑,缩小问题规模,即递归函数内部的操作:抽象出一个干净利落的重复的逻辑

递归算法的编程模型

1、在递去的过程中解决问题

function recursion(大规模)if end_condition:  # 明确的递归终止条件
        end  # 简单情景
    else:  # 在将问题转换为子问题的每一步,解决该步中剩余部分的问题
        solve  # 递去
        recursion(小规模)  # 递到最深处后,不断地归来

2、在归来的过程中解决问题

function recursion(大规模)if end_condition:  # 明确的递归终止条件
        end  # 简单情景
    else:  # 在将问题转换为子问题的每一步,解决该步中剩余部分的问题
        recursion(小规模)  # 递去
        solve  # 归来

递归问题分类

1、问题的定义是按递归定义的:斐波纳契数列、阶乘、杨辉三角的取值、回文字符串的判断、字符串全排列、二分查找
2、问题的解法是递归的:汉诺塔问题
3、数据结构是递归的:链表、二叉树等

递归vs循环(迭代)

1、递归通常很直白地描述了一个问题的求解过程,递归的使用能让代码变得简单清晰,逻辑变得易懂,因此也是最容易被想到解决方式;循环其实和递归具有相同的特性,即做重复任务,但有时使用循环的算法并不会那么清晰地描述解决问题步骤,可能会把逻辑隐藏起来——目前来说可能递归的方法还是代码写的太少,所以总是倾向于按照循环迭代的代码写,导致递归的方法特别不熟练
2、在实际开发中,因为函数调用的开销,递归常常会带来性能问题,特别是在求解规模不确定的情况下;而循环因为没有函数调用开销,所以循环效率会比递归高
3、递归求解方式和循环求解方式往往可以互换,也就是说,如果用到递归的地方可以很方便使用循环替换,而不影响程序的阅读,那么替换成循环往往是好的
4、递归实现转换成非递归:建立“堆栈”来保存这些内容以便代替系统栈;把对递归的调用转变为对循环处理

参考文献

1.对于递归有没有什么好的理解方法?

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

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

相关文章

一篇文章教会你C++11入门知识点

C11入门 列表初始化1. {}初始化2. initializer_list 声明1. auto2. decltype3. nullptr 范围for循环STL新增容器1. array2. forward_list3. unordered_map和unordered_set 右值引用和移动语义1. 左值引用和右值引用2. 左值引用和右值引用比较3. 右值引用使用场景和意义4. 右值引…

16-spring AOP核心对象的创建

文章目录 1. aop的几个重要概念2. aop bean definition3. AspectJPointcutAdvisor4.AopConfigUtils5.AnnotationAwareAspectJAutoProxyCreator6. 循环依赖1. aop的几个重要概念 参考官方解释:https://docs.spring.io/spring-framework/docs/5.2.9.RELEASE/spring-framework-r…

操作系统备考学习 day10

操作系统备考学习 day10 第三章 内存管理3.2 虚拟内存管理3.2.1 虚拟内存的基本概念传统存储管理方式的特征、缺点局部性原理虚拟内存的定义和特征如何实现虚拟内存技术 3.2.2 请求分页管理方式页表机制缺页中断机构地址变换机构 3.2.3 页面置换算法最佳置换算法(OP…

总结一下vue中v-bind的常见用法

文章目录 🐕前言:🏨简述一下v-bind命令其它写法 🐕前言: 本篇博客主要总结一下v-bind命令在vue中的常见用法 🏨简述一下v-bind命令 v-bind命令是将动态的数据属性与咱们的标签进行一个绑定,它可以绑定标…

二维码智慧门牌管理系统:革新小区安全管理的新力量

文章目录 前言一、外采人员的数据采集二、二维码智慧门牌管理系统的创新性三、居民的便捷体验四、面临的挑战 前言 在科技快速发展的今天,智能化和数字化已经深刻影响着我们的生活的各个方面。近期备受关注的话题之一是二维码智慧门牌管理系统,这一系统…

缓存失效方案

一、背景 WRITE : 数据写入Mysql 和 Redis缓存, READ:先从 Redis 缓存中取数据,拿不到再从Mysql中加载,更新到Redis 上图第三阶段,接收Mysql的binlog变更消息,可以参考阿里的 Canal&#xff0…

tooltip里面画echarts图

第一步: 第二步; 完整代码: //协作工作受理分析圆柱形workLineChart(xData, yData) {let that this;let option {backgroundColor: "#061326",grid: {top: "10%",bottom: "5%",left: "5%",right: "5%",containLabel: true…

【C语言必知必会 | 子系列第一篇】深入剖析顺序结构(1)

引言 C语言是一门面向过程的、抽象化的通用程序设计语言,广泛应用于底层开发。它在编程语言中具有举足轻重的地位。 此文为【C语言必知必会子系列】第一篇,基于进行C语言顺序结构的选择题专项练习,结合专题优质题目,带领读者从0开…

软件测试01

一、认识软件及测试 1、什么是软件 控制计算机硬件工作的工具 2、软件的基本组成 页面客户端------请求----->代码服务器-------请求------>数据服务器 3、软件产生过程 需求产生------->需求文档------->设计效果图------->产品开发-------->产品测试 …

消失的它:网络层分片包中的第一个分片包去哪了?

在网络层IP包分片的过程中,遇到了大麻烦! 主机A: IP地址:192.168.0.10/24 MAC地址:02:00:00:00:00:10 主机B: IP地址:192.168.0.20/24 MAC地址:02:00:00:00:00:20 MTU:1…

算法通过村第十五关-超大规模|黄金笔记|超大规模场景

文章目录 前言对20GB文件进行排序超大文本中搜索两个单词的最短距离从10亿数字中寻找小于100万个数字总结 前言 提示:你生命的前半辈子或许属于别人,活在别人的认为里。那把后半辈子还给自己,去追随你内在的声音。 --荣格 理解了前面的几个题…

13.Tensor Product:Vector - Covector Pairs

之前对于Tensor 的最好的定义: 需要注意的是:本文的一些内容使用的是非国际标准的符号,只是视频制作人的个人偏好。 如上图:张量是 使用张量积组合在一起的向量和协向量的集合。 所以,向量和协向量就像是所有其他张量…

外包干了2个月,技术退步太明显...

先说情况,大专毕业,18年通过校招进入湖南某软件公司,干了接近4年的功能测试,今年年初,感觉自己不能够在这样下去了,长时间呆在一个舒适的环境会让一个人堕落!而我已经在一个企业干了四年的功能测试&#xf…

网工内推 | 金融业,网络管理岗,CCIE优先,最高30k

01 国民养老保险 招聘岗位:网络管理岗 职责描述: 1.负责公司整体网络架构规划、设计,制定整体网络方案,完善网络拓扑架构标准化文档,对公司现有网络进行梳理及持续优化。 2.负责公司网络系统建设,建立具备…

15-bean生命周期,循环依赖

文章目录 1. bean生命周期 1. bean生命周期

前端学成在线项目详细解析一

学成在线项目 01-项目目录 网站根目录是指存放网站的第一层文件夹&#xff0c;内部包含当前网站的所有素材&#xff0c;包含 HTML、CSS、图片、JavaScript等等。 首页引入CSS文件 <!-- 顺序要求&#xff1a;先清除再设置 --> <link rel"stylesheet" hre…

Hexo搭建个人博客系列之环境准备

环境准备 Git Git官网&#xff0c;安装过程,就是一直下一步,详细的看这篇文章 Git的安装 Node.js Node.js官网 Node.js的安装 注册一个GitHub账号 安装hexo 新建一个文件夹(位置任意),运行cmd(若出现了operation not permitted,就以管理员的权限来运行cmd)&#xff0c;运行…

UE4逆向篇-2_各类数据的查找方式

写在前面 1.通过前面的文章&#xff0c;相信各位已经能够自己找到GNames并使用DUMP工具导出GNames了。 2.本篇文章将介绍各种所需数据的查找方法。 一、准备工作 1.CheatEngine&#xff0c;本篇以及后续篇幅的重要工具。 2.一个记事本&#xff0c;保证你能记录下关键信息。…

代码随想录算法训练营第五十七天 | 392.判断子序列、115.不同的子序列

392.判断子序列 链接&#xff1a; 代码随想录 115.不同的子序列 链接&#xff1a; 代码随想录

高校教务系统登录页面JS分析——华南农业大学

高校教务系统密码加密逻辑及JS逆向 本文将介绍高校教务系统的密码加密逻辑以及使用JavaScript进行逆向分析的过程。通过本文&#xff0c;你将了解到密码加密的基本概念、常用加密算法以及如何通过逆向分析来破解密码。 本文仅供交流学习&#xff0c;勿用于非法用途。 一、密码加…