百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

C++中的递归 c++中递归函数的使用方法

yuyutoo 2024-12-17 17:24 3 浏览 0 评论

1.概念

递归函数即自调用函数,在函数内部直接的或者间接地调用自己。在求解某些具有随意性的复杂问题时经常使用递归,如要求编写一个函数,将输入的任意长度的字符串反向输出。普通做法是将字符串放入数组中然后将数组元素反向输出即可,然而这里的要求是输入是任意长度的,总不能开辟一个很大的空间保存字符串吧?这时候递归就起作用了。递归采用了分治的思想,将整体分割成部分,从最小的基本部分入手,逐一解决,其中部分通常和整体具有相同的结构,这样部分可以继续分割,直到最后分割成基本部分。

递归函数必须定义一个终止条件,即什么情况下终止递归,终止继续调用自己,如果没有终止条件,那么函数将一直调用自己,知道程序栈耗尽,这时候等于是写了一个Bug!

总结递归的特点:

(1) 使用递归时,一定要有明确的终止条件!

(2) 递归算法解题通常代码比较简洁,但不是很容易读懂。

(3) 递归的调用需要建立大量的函数的副本,尤其是函数的参数,每一层递归调用时参数都是单独的占据内存空间,他们的地址是不同的,因此递归会消耗大量的时间和内存。而非递归函数虽然效率高,但相对比较难编程。

(4) 递归函数分为调用和回退阶段,递归的回退顺序是它调用顺序的逆序。

2.实践

斐波那契数列当n>3时,第n个元素的值等于第n-1个元素和n-2个元素的和,当n不确定具体数值时,可以通过递归的方式实现

int Fib(int n) {
 if (n < 2)
 return 1;
 return Fib(n - 1) + Fib(n - 2);
}
void test_fib(int n) {
 int fib1[n], fib2[n];
 fib1[0] = 1;
 fib1[1] = 1;
 fib2[0] = 1;
 fib2[1] = 1;
 for (int i = 2; i < n; i++) {
 fib1[i] = Fib(i);
 fib2[i] = fib2[i - 1] + fib2[i - 2];
 }
 cout << "use func Fib() " << endl;
 for (int i = 0; i < n; i++) {
 cout << fib1[i] << ' ';
 }
 cout << endl;
 cout << "use for loop " << endl;
 for (int i = 0; i < n; i++) {
 cout << fib2[i] << ' ';
 }
 cout << endl;
}

最终由递归得到的斐波那契数列和由for循环得到的数列相同。

阶乘问题同样可以通过递归实现,代码为

int Factorial(int n) {
 if (n == 1)
 return 1;
 return n * Factorial(n - 1);
}

当n=5时,函数的调用过程如下图所示

汉诺塔问题是指一共有3根针,其中两根为空,另外一根针从上到下按照尺寸穿好了若干个盘子,上面的小下面的大,要求是每次移动一个盘子,将所有的盘子移动到另一根针上,并且所有的针上的盘子都满足上小下大的要求,如下图

这个问题同样可以使用递归的方式解决,思路如下

因此发现以上步骤实际上是一个重复的过程,则整个问题可以使用递归解决,当盘子个数为1时直接移动即可,为n时则先借助一根针将n-1个盘子移动到另一根针上,而n-1根针可以先移动n-1-1根针,如此往复。代码如下

void move(int n, char x, char y, char z) {
 // 将n个盘子从x借助y移动到z上
 if (1 == n) {
 cout << x << "-->" << z << endl;
 } else {
 // 将n-1个盘子从x借助z移动到y上
 move(n - 1, x, z, y);
 // 将第n个盘子从x移动到z上
 cout << x << "-->" << z << endl;
 // 将n-1个盘子从y借助x移动到z上
 move(n - 1, y, x, z);
 }
}

最后,如果你想学C/C++可以私信小编“01”获取素材资料以及开发工具和听课权限哦!

相关推荐

使用 Node.js、Canvas 和 FFmpeg 实时生成并推送视频流

1、背景和需求在许多实时视频应用场景中,我们需要动态生成实时视频流并将其推送到RTMP服务器。例如,我们可能需要生成一个实时显示当前时间的视频流,或者在游戏直播时显示实时弹幕等。本文将介绍如何使...

熊孩子高空泼墨,全楼都遭殃!父母的反应让全网点赞

自家熊孩子从楼上泼墨邻居晾的衣服、楼的外墙…无一幸免!事发后孩子父母的反应让全网点赞!5月21日,江苏宿迁。网友“宇兄宇弟”发了几条短视频,只见视频中阳台上晾晒的衣服全都被泼上了墨汁,楼下地上和楼外墙...

动态爬虫(ajax)-爬取bilibili热门视频信息

前言使用python爬虫爬取bilibli每日热门视频的数据使用的第三方软件包括requests、my_fake_useragent...

轻视频课程:AngularJS开发框架实用编程入门之一

这个基础课程将介绍知名的Google前端开发框架AngularJS的基础使用,包括:基本概述,数据绑定,指令,表达式,控制器,过滤器等基础内容课程内容:AngularJS核心功能数据绑定:自动同步视图...

html5的video标签实现对m3u8格式视频(HLS)的支持 亲测可用

在切图网一个项目切图中遇到的,网页中嵌入视频理所当然用html5自带的video标签即可实现,也有比较主流的插件videojs,但是这个比较特别播放的视频是m3u8格式的(这种好像imacsaf...

html5的video标签实现m3u8格式的支持,基于hls.min.js

切图网站的踩坑笔记,vue开发项目中通过api接口获取到了m3u8格式的音频,但是有的浏览器默认不支持,所以需要借助辅助手段来实现,下面介绍详细方法。什么是m3u8?m3u8是m3u的一种,是utf-...

基于 vue.js+xgplayer 开源音视频播放器组件

今天继续给小伙伴们分享一个西瓜视频播放器Vue组件XGPlayer-Vue。xgplayer-vue西瓜视频播放器xgplayer的vue.js版本组件。安装...

盘点戏精萌娃的搞笑日常,好看吗?

孩子们搞笑的日常。盘点戏精萌娃的搞笑日常。好看吗?你这不是难为我吗?这咋难为你了,你别怪我说话直,那你也别怪我下手重。我这一身傲骨还能不怕你威胁吗?就让你看这衣服好不好看,怎么这么费劲?衣服。...

WEB页面页面播放实时视频流

业务述求需要在WEB端实时查看现场的视频监控(公司选型的是大华摄像机)1技术方案选型1.ffmpeg通过rtsp协议拉取视频流2.使用vlcmediaplayer组件拉取视频流,在...

科研笔记神器:??一边视频,一边笔记,轻松搞定B站视频学习

上一期,笔者介绍了一款笔记神器——Obsidian,它可以用于思维导图和知识管理。...

在网页上显示监控视频

最近需要在web项目中显示监控视频,采用了webrtc+webrtc-streamer+coturn的方案实现,能够在公网上做很低的延时,对于实时监控视频有很好的效果,是目前来讲比较好的一个选择方案...

Node.js服务端使用ffmpeg压缩视频处理技巧

在Node.js中,我们可以使用fluent-ffmpeg进行视频的合并、拼接、修改、转码、压缩等操作。网上的资料有很多,但是大部分是英文的,对于普通开发者来说,要轻松地了解使用方法还是很有难度的。...

杜淳晒女儿跑步萌态,1岁小蛋饺步伐超稳,全身肉嘟嘟可爱爆棚

4月27日下午,杜淳在个人社交平台分享了一段女儿小蛋饺跑步的萌态,老父亲还感慨写道:“奔跑吧,我的小蛋饺,跑着跑着就长大了,我的小公主”。杜淳自从升级奶爸后,这“女儿奴”属性真是愈发明显了,每一次晒与...

8款测试HLS m3u8视频流的免费在线播放器

翻译:Alex技术审校:纪永康本文来自OTTVerse,作者为KrishnaRaoVijayanagar。...

HLS视频拉流播放

1、安装HlsVue.js是一个适用于构建用户界面的渐进型框架,它的流行程度已经在现代Web应用开发领域中得到了广泛的认可。而HLS(HTTPLiveStreaming)则是一种广泛应用于视频流媒...

取消回复欢迎 发表评论: