【算法】递归算法理解(持续更新)

这里写目录标题

  • 一、递归算法
    • 1、什么情况下可以使用递归?
    • 2、递归算法组成部分
    • 3、案例:求n的阶乘
    • 4、编写一个递归函数来计算列表包含的元素数。
    • 5、通过递归找到列表中最大的数字。
    • 6、通过递归的方式实现二分查找算法。

在这里插入图片描述

一、递归算法

递归(Recursion)是一种解决问题的思路,其精髓在于将问题分解为规模更小的相同问题,持续分解,直到问题规模小到可以用非常简单直接的方式来解决。递归的问题分解方式非常独特,其算法方面的明显特征就是:在算法流程中调用自身。

在调试递归算法程序的时候经常会碰到这样的错误:RecursionError: maximum recursion depth exceeded in comparison,原因递归的层数太多,但系统调用栈容量是有限的。

递归示意图如下:求1到10内的奇数和
在这里插入图片描述

1、什么情况下可以使用递归?

1个问题可以拆分为多个子问题
这些问题求解思路相同,数据规模不同
拥有明确的的终止条件

2、递归算法组成部分

基准条件(递归结束条件)
递归条件
如何分解问题,最终能让递归终止

3、案例:求n的阶乘

基准条件为(结束条件):函数不在调用自己
递归条件:函数调用自己
如何分解问题:让n在每次执行完之后,都减小

def factorial(n):# 基线条件(结束条件):函数不再调用自己if n == 1:return 1# 递归条件:函数调用自己# 让n在每次执行完之后,都变小res = n * factorial(n - 1)return resprint(factorial(4))

4、编写一个递归函数来计算列表包含的元素数。

基线条件:当列表不为空列表时一直删除,删除到空就停止
递归条件,一直传递被修改的列表,以及最后的累加和的变量
问题如何分解:每累加一个元素,就把这个元素在列表里面去掉

nums=[1,2,3,4]
def list_sum(nums,sum_data=0):#基线条件:当列表为空列表一直删除,删除到空就停止if len(nums)==0:return sum_data# 递归条件,一直传递被修改的列表,以及最后的累加和的变量# 递归条件,问题如何分解:每累加一个元素,就把这个元素在列表里面去掉pop_data=nums.pop()sum_data=sum_data+pop_datareturn list_sum(nums,sum_data)nums=[1,2,3,4]
print(list_sum(nums))

5、通过递归找到列表中最大的数字。

基线条件:当列表不为空列表时,一直删除,删除到空停止
递归条件,一直传递修被修改的列表,以及最大值的变量
问题如何分解:每比对一个元素,就把这个元素在列表中删除

def list_max(nums,max_value=0):# 基线条件:当列表为空列表,一直删除,删除到空停止if len(nums)==0:return max_value# 递归条件,一直传递修被修改的列表,以及最大值的变量# 递归条件,问题如何分解:每比对一个元素,就把这个元素在列表中删除pop_data=nums.pop()max_value=max(max_value,pop_data)return list_max(nums,max_value)nums=[1,5,3,4]
print(list_max(nums))

6、通过递归的方式实现二分查找算法。

在这里插入图片描述

基线条件:当nums[mid]==target时停止;或者当left<=right时停止;
递归条件,一直更新左右指针,并且满足left<=right时
问题如何分解:每次计算mid=(left+right)//2的值后,对nums[mid]与target进行对比,来改变左或者右指针。

二分查找是一种在有序数组中查找元素的算法;将数组分成两部分,判断目标元素可能在哪一部分;直到找到元素或者确定目标元素不存在于数组中。
思路:
1、确定查找范围
2、获取中间元素
3、如果数字小了,就修改最小值
4、如法数字大了,就修改最大值
5、如果猜中了,则返回下标
6、重复以上的过程指导找到目标元素或者u其额定目标元素不存在于数组中

def digui_search(nums,left,right,target):while left<=right:mid=(left+right)//2if nums[mid]==target:return midelif nums[mid]>target:right=mid-1digui_search(nums,left,right,target)else:left=mid+1digui_search(nums,left,right,target)return -1
nums=[1,3,5,7,9]
target=2
print(digui_search(nums,0,4,target))

不采用递归的方法,进行二分查找

def binary_search(nums, target):# 第一个下标low = 0# 最后一个下标high = len(nums) - 1# 只要最小值一直小于最大值,那么就一直循环查找while low <= high:# 获取中间值的下标值,向下整除mid = (low + high) // 2if nums[mid] == target:return mid# 如果中间值小于目标值,修改最小值elif nums[mid] < target:low = mid + 1# 如果中间值大于目标值,修改最大值else:high = mid - 1# 重复以上的过程指导找到目标元素或者u其额定目标元素不存在于数组中return -1

在这里插入图片描述


在这里插入图片描述

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

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

相关文章

“单项突出”的赢双科技IPO加速,比亚迪是最强助力?

近日&#xff0c;新能源汽车核心部件供应商赢双科技首次递表科创板&#xff0c;其凭借旋转变压器产品就坐稳了新能源车企主要供应商的地位&#xff0c;从核心业务及业绩情况来看&#xff0c;赢双科技不愧为“单项冠军”。 据悉&#xff0c;赢双科技本次IPO拟募资8.47亿元&…

3.9 EXERCISES

矩阵加法需要两个输入矩阵A和B&#xff0c;并产生一个输出矩阵C。输出矩阵C的每个元素都是输入矩阵A和B的相应元素的总和&#xff0c;即C[i][j] A[i][j] B[i][j]。为了简单起见&#xff0c;我们将只处理元素为单精度浮点数的平方矩阵。编写一个矩阵加法内核和主机stub函数&am…

P9 视频码率及其码率控制方式

前言 从本章开始我们将要学习嵌入式音视频的学习了 &#xff0c;使用的瑞芯微的开发板 &#x1f3ac; 个人主页&#xff1a;ChenPi &#x1f43b;推荐专栏1: 《C_ChenPi的博客-CSDN博客》✨✨✨ &#x1f525; 推荐专栏2: 《Linux C应用编程&#xff08;概念类&#xff09;_C…

一款开源的MES系统

随着工业4.0的快速发展&#xff0c;制造执行系统&#xff08;MES&#xff09;成为了智能制造的核心。今天&#xff0c;将为大家推荐一款开源的MES系统——iMES工厂管家。 什么是iMES工厂管家 iMES工厂管家是一款专为中小型制造企业打造的开源MES系统。它具备高度的可定制性和灵…

Jenkins集成部署java项目

文章目录 Jenkins简介安装 Jenkins简介 Jenkins能实时监控集成中存在的错误&#xff0c;提供详细的日志文件和提醒功能&#xff0c;还能用图表的形式形象的展示项目构建的趋势和稳定性。 官网 安装 在官网下载windows版本的Jenkins 但是我点击这里浏览器没有反应&#xff0…

关于自增和自减的一些细节问题

目录 基本概念 1.运算 2.输出 基本概念 在这里简单回顾一下自增和自减&#xff1a;顾名思义&#xff0c;自就是同一变量的值发生变化&#xff0c;自增就是该变量值加1&#xff0c;自减就是该变量值减1。 自增和自减又可以根据运算符的位置不同分为前缀式和后缀式。前缀就是…

hfish蜜罐docker部署

centos 安装 docker-CSDN博客Docker下载部署 Docker是我们推荐的部署方式之一&#xff0c;当前的版本拥有以下特性&#xff1a; 自动升级&#xff1a;每小时请求最新镜像进行升级&#xff0c;升级不会丢失数据。数据持久化&#xff1a;在宿主机/usr/share/hfish目录下建立dat…

Unity 使用Sprite绘制一条自定义图片的线

Unity 使用Sprite绘制一条自定义图片的线 前言项目场景布置代码编写总结 运行效果感谢 前言 遇到一个需要绘制自定义形状的需求。那只能利用Sprite来绘制一条具有自定义图片的线&#xff0c;通过代码动态设置起点、终点以及线宽&#xff0c;实现灵活的线条效果。 项目 场景…

2024.1.3力扣每日一题——从链表中移除节点

2024.1.3 题目来源我的题解方法一 递归方法二 栈方法三 反转链表方法四 单调栈头插法 题目来源 力扣每日一题&#xff1b;题序&#xff1a;2487 我的题解 方法一 递归 当前节点对其右侧节点是否删除无影响&#xff0c;因此可以对其右侧节点进行递归移除。 若当前节点为空&am…

BLE Mesh蓝牙组网技术详细解析之Access Layer访问层(六)

目录 一、什么是BLE Mesh Access Layer访问层&#xff1f; 二、Access payload 2.1 Opcode 三、Access layer behavior 3.1 Access layer发送消息的流程 3.2 Access layer接收消息的流程 3.3 Unacknowledged and acknowledged messages 3.3.1 Unacknowledged message …

Python selenium实现断言3种方法解析

1.if ...else ...判断进行断言 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 from time import * from selenium import webdriver def login(user"admin",pwd"123456"): driver webdriver.Chrome() driver.implicitly_wait(10)…

RedisInsight - Redis官方可视化工具

一、RedisInsight 简介 RedisInsight 是一个直观高效的 Redis GUI 管理工具&#xff0c;它可以对 Redis 的内存、连接数、命中率以及正常运行时间进行监控&#xff0c;并且可以在界面上使用 CLI 和连接的 Redis 进行交互&#xff08;RedisInsight 内置对 Redis 模块支持&#…

C语言--结构体详解

C语言--结构体详解 1.结构体产生原因2.结构体声明2.1 结构体的声明2.2 结构体的初始化2.3结构体自引用 3.结构体内存对齐3.1 对齐规则3.2 为什么存在内存对齐3.3 修改默认对⻬数 4. 结构体传参 1.结构体产生原因 C语言将数据类型分为了两种&#xff0c;一种是内置类型&#xf…

防火安全球阀,到2027年市场增长至68亿美元

防火安全球阀是一种在火灾、爆炸等危险环境下仍能正常使用的阀门。它被广泛用于石化、化工、船舶、电力等领域&#xff0c;以保障生产和人员安全。下面我们将从全球市场和中国市场两个方面对其发展趋势进行分析。全球市场分析&#xff1a; 从全球市场的角度来看&#xff0c;防火…

软件测试|Linux基础教程:ln命令与软链接和硬链接

简介 在Linux系统中&#xff0c;ln命令是一个非常有用的工具&#xff0c;用于创建链接&#xff08;link&#xff09;&#xff0c;将一个文件或目录链接到另一个位置。链接允许一个文件或目录可以同时存在于多个位置&#xff0c;而不会占用额外的磁盘空间。ln命令支持创建硬链接…

UI5与后端的文件交互(四)

文章目录 前言一、后端开发1. 新建管理模板表格2. 新建Function&#xff0c;动态创建文档 二、修改UI5项目1.Table里添加下载证明列2. 实现onClickDown事件 三、测试四、附 前言 这系列文章详细记录在Fiori应用中如何在前端和后端之间使用文件进行交互。 这篇的主要内容有&…

Unity 打包AB 场景烘培信息丢失

场景打包成 AB 资源的时候&#xff0c;Unity 不会打包一些自带相关的资源 解决办法&#xff1a;在 Project settings > Graphics下设置&#xff08;Automatic 修改成 Custom&#xff09;

selenium对于页面改变的定位元素处理办法

在学习selenimu中&#xff0c;总是发现元素定位不到&#xff0c;想了各种办法&#xff0c;最后总结大致有两个原因。 1.等待时间不够&#xff0c;页面还没有完全渲染就进行操作&#xff0c;使用time模块进行等待。 2.换了页面后&#xff0c;发现定位不到元素&#xff0c;因为…

HTML5和JS实现明媚月色效果

HTML5和JS实现明媚月色效果 先给出效果图&#xff1a; 源码如下&#xff1a; <!DOCTYPE html> <html> <head><title>明媚月光效果</title><style>body {margin: 0;overflow: hidden;background-color: #000; /* 添加一个深色背景以便看到…

安全与认证Week3

目录 Key Management 密钥管理 密钥交换、证书 密钥的类别 密钥管理方面 密钥分发问题 密钥分发方案 混合密钥分发 公钥分发 公钥证书 X.509 理解X.509 X.509证书包含 X.509使用过程 X.509身份验证服务 X.509版本3 取消 由X.509引申关于CA 用户认证、身份管理…