统计c语言中英文字幕,C语言日记——递归

C语言日记——递归

首先,允许我从《c primer plus》中摘一句话:C允许函数调用它自己,这种调用称为递归。

有一段时间一直搞不清楚递归的实质,直到看到如下代码:

#include

int up_and_down(int n);

int main() {

up_and_down(1);

return 0;

}

int up_and_down(int n)

{

printf("Level %d:n location %p\n",n,&n); // #1

if (n < 4) up_and_down(n +

1);

printf("LEVEL %d:n location %p\n",n,&n); // #2

return 0;

}

运行结果:

Level 1:n location 012FFB3C

Level 2:n location 012FFB2C

Level 3:n location 012FFB1C

Level 4:n location 012FFB0C

LEVEL 4:n location 012FFB0C

LEVEL 3:n location 012FFB1C

LEVEL 2:n location 012FFB2C

LEVEL 1:n location 012FFB3C

请按任意键继续. . .

这个结果当你认识递归后就不会觉得有半点奇怪了。

想要真正搞懂递归,这段代码值得上机推敲,最好用调试一步步看看程序的执行顺序。

这里讲下我的个人理解:

首先程序执行主函数main(),在里面调用up_and_down()函数(此时参数为n=1,记住在主函数中该函数只调用了一次,虽然这句话有点多余但我还是觉得有必要提醒)

接着进入了被调函数up_and_down()(这里的被调函数是相对main()而言)

在up_and_down()中,首先打印#1(看上面代码注释)

然后执行up_and_down(1+1),即在up_and_down(1)中调用up_and_down(2)

在这里up_and_down(1)为up_and_down(2)的主调函数,后者则为前者的被调函数

记住这点就好理解了,我们都知道在一个函数中,调用另一个函数执行完以后要返回主调函数

即在up_and_down(1)中调用up_and_down(2)

在up_and_down(2)中调用up_and_down(3)

在up_and_down(3)中调用up_and_down(4)

直到up_and_down(4)打印完#1后不符合(n<4)停止调用,随即跳过if语句直接打印#2

在这里会发现#2是第一次打印,因为在前面几次调用中都还没运行到打印#2这段代码

重点来了,打印完#2后意味着up_and_down(4)调用完毕了,则按照上面说的调用完后返回主调函数

而up_and_down(4)的主调函数是up_and_down(3)

返回up_and_down(3)后程序继续运行,在up_and_down(3)中打印#2(因为在之前up_and_down(3)调用了up_and_down(4),未来得及运行打印#2)

up_and_down(3)打印#2后就等于up_and_down(3)调用完毕了,这里我们又要记住up_and_down(3)是在up_and_down(2)中被调用的,调用完后返回up_and_down(3)的主调函数up_and_down(2)

同理up_and_down(2)调用完后返回至up_and_down(1),而up_and_down(1)才是真正的主函数main()的被调函数,up_and_down(1)执行完毕后返回至main()函数,main()函数再继续执行剩下的代码,这里是return

0;

啰嗦了那么多,其实第一遍看完可能还是捋不清,在这里需要记住,递归其实就是函数自己不断调用自己,弄清楚递归完一层要返回哪一层,代码的执行顺序都是从上往下的,耐心点一步步看下去两三遍后就会恍然大悟。

以上纯为个人理解,如有错误希望指出,大家一起学习,共同进步!

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

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

相关文章

gnu linux中 使用,在Linux上使用GNU sed的方法

grep 命令grep 在文件(或命令输出)中搜索指定正则表达式&#xff0c;并且在标准输出中输出匹配的行。样例显示文件 /etc/passwd 中用户 gacanepa 的信息&#xff0c;忽略大小写。#grep-i gacanepa /etc/passwd显示 /etc 文件夹下所有 rc 开头并跟随任意数字的内容。#ls-l /etc …

android开机自动开启zram,低内存配置  |  Android 开源项目  |  Android Open Source Project...

Android 支持内存为 512 MB 的设备。本文档旨在帮助 OEM 优化和配置 Android 内核 4.4&#xff0c;使其能够在低内存设备上运行。在下文所述的优化措施中&#xff0c;有几项非常通用&#xff0c;甚至也可应用于以前的版本。Android 内核 4.4 平台优化改善了内存管理采用了经验证…

android 自动 键盘,关于Android中的软键盘

InputMethodService为我们的输入法创建了一个Dialog&#xff0c;并且将该Dialog的Window的某些参数(如Gravity)进行了设置&#xff0c;使之能够在底部或者全屏显示。当我们点击输入框时&#xff0c;系统对活动主窗口进行调整&#xff0c;从而为输入法腾出相应的空间&#xff0c…

Android渠道包自动发布市场,Android Gradle实现打包指定渠道后自动上传到fir

fir分三个主要步骤1.获取fir上传凭证2.上传APKAPP logo图标3.获取最新的下载地址供别人下载注&#xff1a;python使用的是requests网络请求库1.获取fir上传凭证image.png代码如下&#xff1a;# 第一步&#xff1a;获取fir上传凭证print("get fir upload certificate"…

android studio vfs,Android Studio:尝试呈现XML布局的InvalidVirtualFileAccessException

我正在尝试在我的应用中预览xml布局(任何xml布局).我正在使用Android Studio 1.5 Preview 2.我一遍又一遍地收到此错误:InvalidVirtualFileAccessException:访问无效的虚拟文件:file:// D:/Scott/Android/Studio/MyApp/app/build/intermediates/classes/debug/com/scott/myapp/…

android 基类fragment,Android DialogFragment 基类的定制

鸿洋博客介绍&#xff1a;DialogFragment的基本使用好处&#xff1a;1&#xff1a;使用DialogFragment来管理对话框&#xff0c;当旋转屏幕和按下后退键时可以更好的管理其声明周期&#xff0c;它和Fragment有着基本一致的生命周期2.DialogFragment也允许开发者把Dialog作为内嵌…

升级鸿蒙系统无法选择应用,申请鸿蒙系统有一个应用选择怎么选择呢

[分享交流]申请鸿蒙系统有一个应用选择怎么选择呢34364电梯直达huafen774590890新学乍练发表于 2020-12-18 22:19:17来自&#xff1a;HUAWEI Mate 30 Pro 5G最新回复 2020-12-19 09:31:55要怎么选择大家知道吗&#xff1f;想着你的狼自成一派发表于 2020-12-18 22:22:29来自&am…

html5 网页游戏论文,JavaScript编写的网页小游戏,很给力

以下为游戏代码&#xff1a;var timerID null;var INT 40;var loadFLG 0;var gameFLG 0;var missFLG 0;var tim 0;var blcol new Array(5); // block colorvar blsta new Array(40); // block statusvar blNO new Array(40); // block Novar blclr 0; // clear block…

c 插件读取有属性的html6,廖雪峰的JS教程6-jQuery

jQueryjQuery是JavaScript世界中使用最广泛的一个库。jQuery这么流行&#xff0c;肯定是因为它解决了一些很重要的问题。实际上&#xff0c;jQuery能帮我们干这些事情&#xff1a;消除浏览器差异&#xff1a;你不需要自己写冗长的代码来针对不同的浏览器来绑定事件&#xff0c;…

html5中的css特性,浅谈HTML5 CSS3的新交互特性

本文标题的这副图片&#xff0c;是用phosotshop制作的。但是&#xff0c;在搜索引擎中你却无法搜索到它&#xff0c;搜索引擎还没有强大到能够识别图片里面的文字。并且由于图片的体积不算太小&#xff0c;可能网速慢的网友在浏览的时候不得不耐心的等待图片的刷新。那么&#…

html表格通过邮件发送,通过html表格发电子邮件

[email protected]>Create this tableThe field "what" is for different categoriesCREATE TABLE email_notify (ID int(11) DEFAULT ‘0‘ NOT NULL,What varchar(60) DEFAULT ‘0‘ NOT NULL,Name varchar(60) DEFAULT ‘0‘ NOT NULL,Email varchar(60) DEFAU…

计算机专业知识多选题证监会,2019年国家公务员考试中国证监会(计算机类)专业科目考试大纲...

2019年国家公务员考试中国证监会(计算机类)专业科目考试大纲由国家公务员考试网公告解读栏目由提供&#xff0c;更多关于2019国家公务员考试大纲,计算机类国考考试大纲,证监会国考考试大,国家公务员考试公告解读的内容&#xff0c;请关注国家公务员考试网/广东公务员考试网&…

计算机和网络老是断开,电脑插上网线还是显示断开连接怎么办

在网络故障处理中遇到过千奇百怪的问题&#xff0c;这里就说一个比较怪异的问题。一个网线插口&#xff0c;有的电脑插上网线可以正常上网&#xff0c;而有的电脑插上就显示断开连接。试了好多办法&#xff0c;换了网线&#xff0c;换了插口&#xff0c;换了路由器&#xff0c;…

计量经济学第六版计算机答案,伍德里奇计量经济学导论计算机习题第六章第13题c_6.13...

伍德里奇计量经济学导论计算机习题第六章第13题,答案和MATLAB代码clear,clc;% c6.13 by% 打开文字文件和数据文件importdata(meap00_01.des);dataxlsread(meap00_01);% 检验所用数据是否为非空Isnanisnan(data(:,[3,5,8,9]));asum(Isnan);bfind(a0);data1data(b,:);% 变量命名m…

思品课如何使用计算机教学课件,小学思品获奖论文巧用多媒体,优化思品课堂教学...

小学思品获奖论文巧用多媒体&#xff0c;优化思品课堂教学摘要&#xff1a;信息技术辅助课堂教学&#xff0c;有利于促进思想品德课教学内容呈现方式、教师教学方式、学生学习方式和师生互动方式的变革。利用信息技术能提高学生学习思想品德的兴趣&#xff1b;有利于培养学生的…

计算机网络的资源共享功能包,计算机网络的资源共享功能包括

资源共享是现代计算机网络的最主要的作用&#xff0c;它包括软件共享、硬件共享及数据共享。在网络中&#xff0c;多台计算机或同一计算机中的多个用户&#xff0c;同时使用硬件和软件资源。通常多用户同时需要的资源总是超过系统实际物理资源的数量&#xff0c;但采用逻辑(或虚…

《计算机应用基础》期末试卷.,《计算机应用基础》期末试卷(A卷)《计算机应用基础》期末试卷(A卷).doc...

广东外语艺术职业学院成人高等教育2012学年第 一 学期 三年 制2012级 初等教育专业计算机应用基础课程 期末 考试试题试卷类型&#xff1a;A 考试形式&#xff1a;闭卷本试题共 五 大题&#xff0c; 4 页&#xff0c;满分 100 分&#xff0c;考试时间为 120 分钟&#xff0c;答…

计算机学院嘉年华标题,“芯动盛夏 AI创南航” 计算机学院举办第八届计算机嘉年华...

当前&#xff0c;我们正迎来一个科技主导的全智能时代&#xff0c;为激发大家学习探索人工智能的兴趣&#xff0c;切身感受AI科技的魅力所在&#xff0c;计算机科学与技术学院/人工智能学院于6月20日在体育馆广场举办了“芯动盛夏 AI创南航”第八届计算机嘉年华活动。活动中&am…

计算机网络与通信02339,4月全国高等教育自学考试计算机网络与通信试题及答案解析.docx...

4月全国高等教育自学考试计算机网络与通信试题及答案解析.docx精品自学考试资料推荐全国 2018 年 4 月高等教育自学考试计算机网络与通信试题课程代码 02339一、单项选择题本大题共 15 小题&#xff0c;每小题1 分&#xff0c;共 15 分 在每小题列出的四个备选项中只有一个是符…

计算机考研百天,2015考研计算机专业复习百天周计划

计算机百天冲刺周计划学习目标篇百天计划第一周(9月26日—10月6日)1.完成数据结构中线性表的复习;并配以习题巩固练习。2.完成强化课程数据结构第一章的学习&#xff0c;重难点针对复习。3.完成数据结构中栈&#xff0c;队列和数组的复习; 并配以习题巩固练习。4.完成强化课程数…