递归的基本概念

news2024/11/25 0:18:57

 分类:
    直接递归
    间接递归

如果递归函数中调用递归的语句为最后一个执行语句,则称这种递归为尾递归

递归使用条件
    原问题可以划为一个或多个子问题,且子问题的求解方式与原问题相同,只是数量规模不同
    递归的调用次数必须有限
    必须有递归出口

递归的使用情况
    定义是递归的
        求n!
    数据结构是递归的
        单链表
    求解方法是递归的
        Hanoi问题

递归模型的组成
    递归出口
    递归体

栈和递归
    函数调用栈
        函数调用:包括一块代码到另一块代码之间的双向数据传递和执行控制转移
        数据传递通过函数参数和返回值实现,另外调用函数时还要为其局部变量分配空间并在退出时回收
        使用栈帧来支持函数调用
            每次调用函数都会创建一帧,保存返回地址、函数实参和局部变量,并将该帧压入调用栈,成为栈顶,函数一旦执行完毕,对应的帧就出栈,对应的控制权就返回给上层的函数,并按照该帧保存的返回值地址确定程序中继续执行的位置
    递归到非递归的转换
        尾递归法可以通过循环或迭代的方式转换为等价的非递归算法
        可以使用栈来模拟递归的执行过程从而实现转换

比较
    优点:结构简单,易于阅读
    缺点:占用内存多,执行效率低,不易优化

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

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

相关文章

突破职场难题有效沟通、应对压力、提升能力,实现职场成功

在竞争激烈的职场中,我们经常面临各种职场挑战,例如如何有效沟通、应对工作压力以及提升职业能力等。下面分享一下在职场中的经验,帮助你提升职场技能,实现出色表现: 一、高效沟通: 倾听与理解&#xff1…

5.26~5.27

https://blog.csdn.net/m0_72827793/article/details/130478513 接着之前的内容 32bit.exe为何运行不了? 第一个问题当我运行32bbit.exe 那是因为我编译出的程序时64位的程序 64位程序和32位程序,在编译的时候,具有差异,在32位…

Qt_C++读写M1IC卡源码支持windows国产linux操作系统

Android Linux RFID读写器NFC发卡器WEB可编程NDEF文本/智能海报/-淘宝网 (taobao.com) IC卡的特性 1、分为16个扇区,每个扇区为4块,每块16个字节,以块为存取单位; 2、每个扇区有独立的一组密码及访问控制; 3、每张卡有唯一序列号…

HACK ME PLEASE: 1实战演练

文章目录 HACK ME PLEASE: 1实战演练一、前期准备1、相关信息 二、信息收集1、访问网站2、端口扫描2、扫描目录3、访问网站4、访问网站5、扫描目录6、访问网站7、登录MySQL数据库8、查看数据表9、查看users表的内容10、查看tblUsers表内容11、解密12、加密13、修改密码14、查询…

CentOS7.6(Linux)环境下有网和无网安装Docker

1、 服务器有网环境 1.1、手动卸载旧版本 sudo yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-latest-logrotate \docker-logrotate \docker-engine1.2、安装yum-utils sudo yum install -y yum-utils \device-mapper-per…

项目并行管理指南:如何做好多项目管理?

多项目并行已经是大部分企业的现状,多项目并行同时进行已然是大部分企业的现状,同时管理多个项目是一件具有挑战性的,但是有一些方法和工具可以帮助我峨嵋你有条理地实施项目,提高效率,降低工作压力。 一,设…

【C++系列P4】模板搞不懂?脑阔抖三抖!!精讲一篇过!

前言 大家好吖,欢迎来到 YY 滴 C系列 ,热烈欢迎!本章主要内容面向接触过C的老铁,主要内容含 目录 一.模板 1.函数模板 一.函数模板概念 二.函数模板的格式 三.函数模板的实例化 1.隐式实例化 2.显式实例化 3.模板参数的…

多模态应用展望——看图聊天、BLIP2

看图聊天 BLIP2 是 salesforce 公司开源的多模态模型,其大致的原理,可以类比看图写作,当前 AI 在文生图模式之外,也支持图生文模式,可以将照片中的核心元素识别出来。然后把这些元素作为上下文,交给 ChatG…

MYSQL 8 中间字段有NULL 值,还是无法走索引,所以我高估了MYSQL 的查询智商

开头还是介绍一下群,如果感兴趣polardb ,mongodb ,mysql ,postgresql ,redis 等有问题,有需求都可以加群群内有各大数据库行业大咖,CTO,可以解决你的问题。加群请联系 liuaustin3 ,在新加的朋友会分到2群(共…

并查集(算法)

目录 一、并查集的概念二、并查集的使用合并集合连通块中点的数量食物链带权并查集扩展域并查集 一、并查集的概念 最裸并查集: 将两个集合合并。 询问两个元素是否在一个集合当中 ,近乎 O ( 1 ) O(1) O(1) 时间内支持两个操作 基本原理&#xff1a…

chatgpt赋能python:Python文件大小:如何优化和管理您的文件大小

Python 文件大小:如何优化和管理您的文件大小 Python 是世界上最流行的编程语言之一,被广泛用于各种不同的应用程序。但是,随着项目变得越来越复杂,并且在需要处理大量数据的情况下,文件大小经常成为一个问题。因此&a…

数据包伪造、替换、劫持,https劫持之探索和测试

(一)数据包替换攻击 该攻击过程如下:伪造服务器响应客户端的数据包。监听客户端的数据包,用预先伪造的数据包,伪装成服务器返回的数据发送给客户端。 因为攻击者跟目标在同一个局域网,所以攻击者发送的数…

算法27:最长公共子序列——样本模型(4)

目录 简介 题目: 思路: 递归版本: 根据递归 分析推导 动态规划版本: 简介 前面刷了几道题目,都是从暴力递归到递归动态规划的版本,最后演变成纯动态规划的版本。接下来的题目,将会跳过 递…

chatgpt赋能python:Python找出列表中出现最多的元素

Python找出列表中出现最多的元素 介绍 在Python的编程过程中,经常需要处理列表,而处理列表时最常见的问题之一就是如何找出列表中出现最多的元素。在某些情况下,我们可能需要确定列表中重复出现最多的元素,并将其提取出来。Pyth…

[机器学习]线性回归

准备入门一下机器学习算法。 今天学习了线性回归,都是理论的东西,没有对于代码的实现,代码也会跟着进度好好搞一下。 对于线性回归的基础概念,我感觉很依靠概率论和线性代数两门课,作为刚准备完数学一考研的我&#xf…

Systrace系列12 —— CPU Info 解读

本文主要是对 Systrace 中的 CPU 信息区域(Kernel)进行简单介绍,简单介绍了如何在 Systrace 中查看 Kernel 模块输出的 CPU 相关的信息,了解 CPU 频率、调度、锁频、锁核相关的信息。 CPU 区域图例 下面是高通骁龙 845 手机 Systrace 对应的 Kernel 中的 CPU Info 区域(底下…

人工智能轨道交通行业周刊-第46期(2023.5.22-5.28)

本期关键词:数字孪生、AI铁路人、道岔、施封锁、图像质量评价、大模型小型化 1 整理涉及公众号名单 1.1 行业类 RT轨道交通人民铁道世界轨道交通资讯网铁路信号技术交流北京铁路轨道交通网上榜铁路视点ITS World轨道交通联盟VSTR铁路与城市轨道交通RailMetro轨道…

在VIVADO下烧写ZC706板载FLASH的操作步骤

1,原理图分析 首先看原理图,我们兼容ZC706的板子有两片 FLASH,型号是S25FL128A,连接方式如下: 可以看到两片是分别接在了XC7Z045芯片的引脚上,是互不相干的并联方式,每个FLASH芯片支持X4模式,也…

Systrace系列11 —— Triple Buffer 解读

本文主要是对 Systrace 中的 Triple Buffer 进行简单介绍,简单介绍了如何在 Systrace 中判断卡顿情况的发生,进行初步的定位和分析,以及介绍 Triple Buffer 的引入对性能的影响。 怎么定义掉帧? Systrace 中可以看到应用的掉帧情况,我们经常看到说主线程超过 16.6 ms 就会…

第一个Vue程序

什么是MVVM MVVM是Model-View-ViewModel的缩写,是一种软件架构模式,用于将用户界面(UI)的开发与业务逻辑和数据分离开来。 在MVVM架构中,Model代表数据模型层,View代表用户界面层,ViewModel充…