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

递归的个人总结

递归函数(递去、回归)是函数不断的调用自己;

可以按照如下来理解:func1中调用func2,func2中调用func3;

func3函数返回了,继续执行func2中的语句;func2执行完了,继续执行func1之后的语句;fun1执行结束。 

void func3()
{printf("this is  func3\n");return;
}
void func2()
{func3();printf("this is  func2\n");return;
}
void func1()
{func2();printf("this is  func1\n");return;
}
int  main()
{func1();return 0;
}

从上图中可以看出,最后调用的函数先执行完(也是递归中回归的过程),即:this is func3先打印输出。

递归算法(英语:recursion algorithm)是指一种通过重复将问题分解为同类的子问题而解决问题的方法。
递归的三要素:

1.明确函数的功能
2.递归的结束条件
3.函数的等价关系

接下来利用n nn阶乘来讲解这三个条件
任何大于等于1 的自然数n nn阶乘表示方法:
n ! = n × ( n − 1 ) ! ( n > 1 ) 0 ! = 1 ( n = 0 ) n!=n \times(n-1)! \quad (n > 1) \\ 0! = 1 \quad (n = 0)
n!=n×(n−1)!(n>1)
0!=1(n=0)

1.1明确函数的功能
明确我们要写的函数的功能是实现n nn的阶乘,定义函数如下:

// 定义n阶乘函数
 public int factorial(int n){
 
 }

1.2递归的结束条件
由阶乘的表示方法可以看出当n = 0 n = 0n=0时是阶乘的最小值,此时结束继续往下计算阶乘,可以把n = 0 n = 0n=0当做递归的结束条件。同样,当n = 1 n = 1n=1时,1 ! = 1 1! = 11!=1也可以作为递归的结束条件。

// 定义n阶乘函数
 public Integer factorial(int n){
     // 递归的结束条件
     if (n == 1) return 1;

 }
1.3函数的等价关系
第三要素就是,我们要不断缩小参数的范围,缩小之后,我们可以通过一些辅助的变量或者操作,使原函数的结果不变。
由阶乘的表达式可以看出n nn的阶乘与n − 1 n -1n−1阶乘存在的关系式为n ! = n × ( n − 1 ) ! ( n > 1 ) n!=n \times(n-1)! \quad (n > 1)n!=n×(n−1)!(n>1)若已知n − 1 n -1n−1的阶乘,记为f ( n − 1 ) f(n - 1)f(n−1),则当前的n nn的阶乘可以记为f ( n ) = n × f ( n − 1 ) ( n > 1 ) f(n) = n \times f(n -1)\quad (n > 1)f(n)=n×f(n−1)(n>1)
综上递归的三个要素可以得出求n nn阶乘的递归函数为

// 定义n阶乘函数
 public Integer factorial(int n){
     // 递归的结束条件
     if (n == 1) return 1;
    return n * factorial(n - 1);
 }
————————————————
                        
原文链接:https://blog.csdn.net/qq_38670588/article/details/108206613

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

相关文章:

  • 使用PDFBox调整PDF每页格式
  • 【3D reconstruction 学习笔记】
  • (附源码)基于Spring Boot与Vue的宠物用品销售系统设计与实现
  • Qwen及Qwen-audio大模型微调项目汇总
  • 浅析ArcGis中的软件——ArcMap、ArcScene、 ArcGlobe、ArcCatalog
  • AndroidStudio插件出现“Compatible with IntelliJ IDEA only“错误时的解决方案
  • 探索未来的编程趋势与挑战
  • 第十二届蓝桥杯省赛CC++ 研究生组
  • Ubuntu自启GUI程序
  • 【光标精灵】让您享受鼠标皮肤多样化快捷更换
  • Vue 常见面试题(一)
  • Elasticsearch 的 scroll API
  • Leedcode刷题——2 字符串
  • 2016年认证杯SPSSPRO杯数学建模B题(第二阶段)多帧图像的复原与融合全过程文档及程序
  • WMI接口设计实现
  • 前端项目,个人笔记(二)【Vue-cli - 引入阿里矢量库图标 + 吸顶交互 + setup语法糖】
  • OpenCV 介绍使用
  • Python 10个面试题实例
  • Python:熟悉简单的skfuzzy构建接近生活事件的模糊控制器”(附带详细注释说明)+ 测试结果
  • opencv函数使用查找
  • 使用 pypdf 快速切分 PDF 文件
  • Avalonia(11.0.2)+.NET6 打包运行到银河麒麟V10桌面系统
  • Mac nvm install failed python: not found
  • C语言基础知识复习(考研)
  • Prometheus Grafana 配置仪表板
  • docker 哲学 - 网络桥接器、容器网络接口 、容器间的通信方式
  • Python 将HTML转为PDF、图片、XML、XPS格式
  • 排序算法记录(冒泡+快排+归并)
  • 简单聊聊如何更优雅地初始化对象:构造函数、Builder模式和静态工厂方法比较
  • 跳过mysql权限验证来修改密码-GPT纯享版