递归之我见

void diGui()
{
static int i = 2;
if (i == 1)
{
cout << “i: " << i << " 时递归结束\n”;
return ;
}
else
{
cout << "i: " << i << endl;
i–;
diGui();
cout << “j: " << i << " 时递归11\n”;
}
cout << “i: " << i << " 时递归\n”;
int main()
{
diGui();
getchar();
return 0;
}
函数执行过程
1 先进入if判断,i!=1 所以进入else i-- 进入digui()函数
2. i == 1 retrun 上一级函数 digui()这里 执行 cout << “j: " << i << " 时递归11\n”;
3. cout << “i: " << i << " 时递归\n”;

如果把函数变换一下

void diGui()
{
static int i = 2;
if (i == 1)
{
cout << “i: " << i << " 时递归结束\n”;
//return ; – 去掉reurn
}
else
{
cout << "i: " << i << endl;
i–;
diGui(); —返回上一级函数位置
cout << “j: " << i << " 时递归11\n”;
}
cout << “i: " << i << " 时递归\n”; //这里要执行一次,因为没有return
int main()
{
/bool a = diGui();
if (!a) cout << “aa” << endl;
/
diGui();
//int c = fib(5);
//cout << c << endl;
getchar();
return 0;
}

if i = 1 去掉return

函数执行过程
1 先进入if判断,i!=1 所以进入else i-- 进入digui()函数
2. i == 1 retrun 返回上一级函数 digui()这里 执行 cout j <<递归11
3. cout << “i: " << i << " 时递归\n”

<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<

函数执行过程1
1 先进入if判断,i!=1 所以进入else i-- 进入digui()函数
5. i == 1 retrun 返回上一级函数 digui()这里 执行 cout j <<递归11
6. cout << “i: " << i << " 时递归\n”

函数执行过程2
1 先进入if判断,i!=1 所以进入else i-- 进入digui()函数
2.if i == 1 cout << “i: " << i << " 时递归\n”; 后 再返回上一级函数 digui()
这里 执行 cout << “j: " << i << " 时递归11\n”;
7. cout i << 递归

两个对比可以看出多执行了一次cout << “i: " << i << " 时递归\n”

递归的过程大概就是最后一层函数执行完之后,不管有没有return,一定会返回到上一级digui()函数那里,不是整个函数重新执行一波

#include
using namespace std;
int diGui();
int fib(int n)
{
if (n <= 0) //基本情况
return 0;
else if (n == 1) // 基本情况
return 1;
else
return fib(n - 1) + fib(n - 2);
}
//实现一个简单的递归
int main()
{
/bool a = diGui();
if (!a) cout << “aa” << endl;
/
int c = diGui();
//int c = fib(5);
//cout << c << endl;
getchar();
return 0;
}
int diGui()
{
static int i = 3;
if (i == 1)
{
cout << “i: " << i << " 时递归结束\n”;
return i ;
}
else
{
cout << "i: " << i << endl;
i–;
return diGui()+1;
cout << “j: " << i << " 时递归11\n”;
}
cout << “i: " << i << " 时递归\n”;
}
再来看这个例子
1 当i =1 return 1
2 返回上级函数 return digui()+1,这里digui()返回的是1 所以return 1+1
3.在返回上一级函数 return digui()+1 ,这里digui()返回的值是1+1,所以返回 1+1+1
4整个递归函数完成
5 int c =3

在变换一下例子
#include
using namespace std;
int diGui();
int fib(int n)
{
if (n <= 0) //基本情况
return 0;
else if (n == 1) // 基本情况
return 1;
else
return fib(n - 1) + fib(n - 2);
}
//实现一个简单的递归
int main()
{
/bool a = diGui();
if (!a) cout << “aa” << endl;
/
int c = diGui();
//int c = fib(5);
//cout << c << endl;
getchar();
return 0;
}
int diGui()
{
static int i = 3;
if (i == 1)
{
cout << “i: " << i << " 时递归结束\n”;
return i ;
}
else
{
cout << "i: " << i << endl;
i–;
return diGui(); – 去掉+1
cout << “j: " << i << " 时递归11\n”;
}
cout << “i: " << i << " 时递归\n”;
}

来看这个例子
1 当i =1 return 1
2 返回上级函数 return digui(),这里digui()返回的是1 所以return 1
3.在返回上一级函数 return digui() ,这里digui()返回的值是1,所以返回 1
4整个递归函数完成
5 int c =1

了解这4个例子递归的基本流程就懂了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
CSDN海神之光上传的全部代码均可运行,亲测可用,尽我所能,为你服务; 1、代码压缩包内容 主函数:main.m; Fig:GUI操作界面; 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,可私信博主; 3、运行操作步骤 步骤一:将所有文件放到 Matlab的当前文件夹中; 步骤二:双击打开main.m文件;(若有其他m文件,无需运行) 步骤三:点击运行,等程序运行完得到结果; 4、语音处理系列仿真咨询 如需其他服务,可私信博主或扫描博主博客文章底部QQ名片; 4.1 CSDN博客或资源的完整代码提供 4.2 期刊或参考文献复现 4.3 Matlab程序定制 4.4 科研合作 语音处理系列程序定制或科研合作方向:语音隐藏、语音压缩、语音识别、语音去噪、语音评价、语音加密、语音合成、语音分析、语音分离、语音处理、语音编码、音乐检索、特征提取、声源定位、情感识别、语音采集播放变速等; CSDN海神之光上传的全部代码均可运行,亲测可用,尽我所能,为你服务; 1、代码压缩包内容 主函数:svddwt.m; 调用函数:其他m文件; 语音信号,其格式为MP4; 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,可私信博主; 3、运行操作步骤 步骤一:将所有文件放到 Matlab的当前文件夹中; 步骤二:双击打开svddwt.m文件;(若有其他m文件,无需运行) 步骤三:点击运行,等程序运行完得到结果; 4、智能优化算法背包问题系列仿真咨询 如需其他服务,可私信博主或扫描博主博客文章底部QQ名片; 4.1 CSDN博客或资源的完整代码提供 4.2 期刊或参考文献复现 4.3 Matlab程序定制 4.4 科研合作 语音处理系列程序定制或科研合作方向:语音隐藏、语音压缩、语音识别、语音去噪、语音评价、语音加密、语音合成、语音分析、语音分离、语音处理、语音编码、音乐检索、特征提取、声源定位、情感识别、语音采集播放变速等;

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值