当前位置: 首页 > news >正文

【c语言】函数递归调用

创作不易,本篇文章如果帮助到了你,还请点赞 关注支持一下♡>𖥦<)!! 

主页专栏有更多知识,如有疑问欢迎大家指正讨论,共同进步!

给大家跳段街舞感谢支持!ጿ ኈ ቼ ዽ ጿ ኈ ቼ ዽ ጿ ኈ ቼ ዽ ጿ ኈ ቼ ዽ ጿ ኈ ቼ

c语言系列专栏: c语言之路重点知识整合  

目录

一、递归基本概念的理解

二、递归算法的基本模式

一些习题实例:

两个正整数的最大公约数

用递归算法实现斐波那契数列


一、递归基本概念的理解

函数递归就是函数在其内部再次调用自己的过程。

递归是一种解决问题的方法,它将问题分解成更小的子问题,直到这些子问题的解决方法变得简单明了。在递归过程中,当执行到一个终止条件时,递归过程就会结束,返回结果给上一级递归函数,并依次返回给最初调用的函数。

递归算法在解决一些实际问题时会更简单明了 

二、递归算法的基本模式

递归算法的基本模式:终止条件,递推公式

例如:        计算阶乘5*4*3*2*1=

#include <stdio.h>
int fun01(int n);
int main()
{printf("%d\n",fun01(5));return 0;
}int fun01(int n)
{if (n==1)        //终止条件{return 1;          }return n*fun01(n-1);    //递推公式
}

阶乘计算到1,终止条件为n==1

阶乘计算为前一个数累乘到后一个数,递推公式为   n*fun01(n-1)

一定要有终止条件!!因为没有终止条件会一直循环,过度递归可能会导致栈溢出。

一些习题实例:

两个正整数的最大公约数

不断向下取余,直到取尽

#include <stdio.h>
int fun11(int m,int n);
int main()
{/* 递归实现:两个正整数的最大公约数 */printf("%d\n",fun11(124,36));return 0;
}int fun11(int m,int n)
{if (m % n == 0){return n;}return fun11(n, m % n);
}

使用调试器查看:

 最终返回结果为4

用递归算法实现斐波那契数列

后一项等于前两项之和,直到开头两项为止 

#include <stdio.h>
int fun13(int n);
int main()
{/*用递归算法实现斐波那契数列: */int i;for(i=1;i<=20;i++){printf("%d,",fun13(i));}return 0;
}
int fun13(int n)
{if (n<=2){return 1;}return fun13(n-1)+fun13(n-2);
}

大家的点赞、收藏、关注将是我更新的最大动力!欢迎留言或私信建议或问题。
大家的支持和反馈对我来说意义重大,我会继续不断努力提供有价值的内容! 

http://www.lryc.cn/news/64651.html

相关文章:

  • SPSS如何进行判别分析之案例实训?
  • Windows 10 字体模糊发虚的问题及解决方法
  • 渔人杯部分wp
  • 测试用例覆盖不全面的解决方法
  • AWS Lambda - 第一部分
  • Java 基础进阶篇(七)—— 面向对象三大特征之三:多态
  • day9 实现UDP通信
  • 自然语言处理(NLP)在放射学报告评价中的应用:应用和技术进展
  • 日常开发为什么需要做Code Review
  • OSPF的优化
  • C++项目中打破循环依赖的锁链:实用方法大全
  • IDEA连接HBase
  • Mask2Former来了!用于通用图像分割的 Masked-attention Mask Transformer
  • 【量化课程】01_投资与量化投资
  • SpringBoot实现导出Excel功能
  • NSSCTF之Misc篇刷题记录⑧
  • 从零开始学习Linux运维,成为IT领域翘楚(七)
  • 优漫动游设计APP的UI界面需要注意哪些问题?
  • 面试 004
  • CCF-202206-2-寻宝!大冒险!
  • 二叉搜索树中的众数
  • 认识JSP
  • MySQL数据管理
  • 第十九章 Unity 其他 API
  • sha256算法详解,用C语言模拟sha256算法
  • 前端技术未来发展展望
  • 第四十六天|dp
  • 汇编语言-复习自用
  • Android moneky自动点击应用设想
  • 16.基于主从博弈理论的共享储能与综合能源微网优化运行研究