简单了解递归

简介: 简单了解递归

递归

​ 递🐢? obviously,no!

​ 简单来说就是一个函数自己调用自己。

#include<iostream>
using namespace std;
void function(int n){
    if(n > 0)function(n - 1);
    cout<<n<<endl;
}
int main(){
    function(3);
    return 0;
}

​ 每调用一次自己就会在栈中开辟一个新的空间来执行该函数。

​ 先在主函数空间执行,

​ 执行到function(3);时,开辟空间执行function(3),

​ 此时n = 3,n > 0,执行function(3 - 1),开辟空间执行function(2),

​ 此时n = 2,n > 0,执行function( 2 - 1),开辟空间执行function(1),

​ 此时n == 1,n > 0,执行function( 1- 1),开辟空间执行function(0),

​ 此时n == 0, 执行输出语句,输出0,

​ 由于function(1)还有语句没执行完,

​ 然后返回执行,function(1)的输出语句,输出1,

​ 由于function(2)还有语句没执行完,

​ 然后返回执行,function(2)的输出语句,输出2,

​ 由于function(3)还有语句没执行完

​ 然后返回执行,function(2)的输出语句,输出3。

image.png

相关文章
|
3月前
递归详解~
递归详解~
29 0
|
3月前
|
算法 C#
C#递归详解
C#递归详解
22 0
|
10月前
C 递归
C 递归。
28 2
|
9月前
|
存储
【递归知识+练习】
【递归知识+练习】
55 0
|
存储 算法 C++
递归的应用
递归的应用
|
Java 数据安全/隐私保护 决策智能
字符串全排列(递归)
字符串全排列,递归的应用
129 0
|
算法 Python
递归的使用
递归的使用
41 0
|
算法 索引
第 6 章 递归
简单的说: 递归就是方法自己调用自己,每次调用时传入不同的变量,递归有助于编程者解决复杂的问题,同时可以让代码变得简洁。
62 0
|
机器学习/深度学习 算法
『递归』整数划分
根据n和m的关系,考虑一下几种情况: (一)当n==1时,无论m的值为多少 ,只有一种划分,即{1} (二)当m==1 时,无论n的值为多少,只有一种划分,即1个n,{n} 。 (三)当n==m时,根据划分中是否包含n,可以分为以下两种情况: (1)划分中包含n的情况,只有一个,即 {n} (2)划分中不包含n的情况,这时划分中最大的数字也一定比n小,即n的所有(n-1)划分,即q(n,n-1)。 因此q(n,m)=1+q(n,n-1) (四)当n<m时,由于划分中不可能出现负数,因此就相当于q(n,n) (五)当n>m 时,根据划分中是否包含最大值m,可以分为以下两种情况:
144 0
|
机器学习/深度学习 算法 物联网
一文看懂递归
一文看懂递归