递归简单举例_递归定义举例

递归简单举例_递归定义举例刚接触递归的同学,可能难以理解递归,难以理解的点可能很多,例如:1.函数为什么可以在自己的内部又调用自己呢?2.既然可以自己调用自己,那么递归运行过程中一定回有很多层相互嵌套,到底什么时候不再嵌套呢?3.递归运行过程中,相互嵌套的多层之间会有参数传递,多层之间是否会相互影响?递归两个要素1.递归边界2.递归的逻辑——递归”公式”递归的过程一定有参数的变化,并且参

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

刚接触递归的同学,可能难以理解递归,难以理解的点可能很多,例如:

1.函数为什么可以在自己的内部又调用自己呢?

2.既然可以自己调用自己,那么递归运行过程中一定回有很多层相互嵌套,到底什么时候不再嵌套呢?

3.递归运行过程中,相互嵌套的多层之间会有参数传递,多层之间是否会相互影响?


递归两个要素

1.递归边界

2.递归的逻辑——递归”公式”

递归的过程一定有参数的变化,并且参数的变化,和递归边界有关系.

在难度较大的题目中,这两者均不容易直接得到.


递归的种种问题,也许理解的同学可能可以用一句话解释清楚,但是不理解的同学再怎么说也没办法理解.

下面通过几个简单的例子【体会】一下递归,先从【感性】的角度理解递归.


1.Fibonacci数

我们直到Fibonacci数的递推公式为:F(0)=F(1)=1,F(n)=F(n-1)+F(n-2) n>=2;

这个明显地给出了递归边界n=0或1的时候F(n)的值,和递归逻辑F(n)=F(n-1)+F(n-2),即递推公式.所以这个递归函数不难书写

#include<iostream>
using namespace std;

int F(int n)//函数返回一个数对应的Fibonacci数
{
	if(n==0 || n==1)//递归边界
		return 1;
	return F(n-1) + F(n-2);//递归公式
}

int main()
{
	//测试
	int n;
	while(cin >> n)
		cout << F(n) << endl;

	return 0;
}

Jetbrains全家桶1年46,售后保障稳定



2.阶乘

阶乘的递归公式为:

递归简单举例_递归定义举例

代码如下:

#include<iostream>
using namespace std;

int F(int n)
{
	if(n==0)//递归边界
		return 1;

	return n*F(n-1);//递归公式
}

int main()
{
	int n;
	cin >> n;
	cout << F(n) << endl;

	return 0;
}


3.数组求和

给一个数组a[]:a[0],a[1],…,a[n-1]如何用递归的方式求和?

仍然是两个问题:递归边界和递归公式.

递归边界是什么?一时不容易想到,但是我们想到了求和,多个数的求和过程是什么,x,y,z,w手动求和的过程是什么?步骤如下:

x+y=a,任务变为a,z,w求和

a+z=b,任务变为b,w求和

b+w=c得出答案

思考一下,【得出答案】这一步为什么就可以得出答案呢?(废话?)是因为,一个数不用相加就能得出答案.

所以,递归的边界就是只有一个数.

所以,递归边界有了,那么递归公式呢?其实手动计算过程中,隐含了递归公式:

递归简单举例_递归定义举例

其中+为求两个数的和,F为求多个数的和的递归函数.代码如下:

#include<iostream>
using namespace std;

int F(int a[],int start,int end)
{
	if(start==end)//递归边界
		return a[start];

	return a[start] + F(a,start+1,end);//递归公式
}

int main()
{
	int a[] = {1,2,3,4,5};
	int s=0,e=4;
	cout << F(a,s,e) << endl;

	return 0;
}


4.求数组元素最大值

手动求最大值的过程是什么,遍历+比较,过程如下:

例如,求3,2,6,7,2,4的最大值:先设置最大值max=-999999,然后将max和数组元素逐个(遍历)比较如果a[i]>max,则更新max的值为a[i],否则max不变,继续向后遍历,直到遍历结束.

max<3,则max=3

max>2,max=3不变

max<6,则max=6

max<7,则max=7

max>2,max=7不变

max>4,max=7不变

遍历结束,max=7为最大值.

和求和类似,递归的公式如下:

递归简单举例_递归定义举例

其中max为求两个数的较大值函数,F为求多个数的最大值的递归函数.代码如下:

#include<iostream>
using namespace std;

#define max(a,b) (a>b?a:b)

int F(int a[],int s,int e)
{
	if(s==e)
		return a[s];
	else if(s+1 == e)//递归边界
		return max(a[s],a[e]);

	return max(a[s],F(a,s+1,e));//递归公式!!!
}

int main()
{
	int a[] = {5,1,4,6,2};
	int s = 0,e = 4;
	cout << F(a,s,e) << endl;

	return 0;
}

之所以,说上面的几个例子是【简单例子】,是因为上述所有的递归都属于【单向递归】.单向递归,递归的路径就是一个方向,所以思路相对比较容易想到.

较难的递归问题,一般都不是单向递归,而是需要使用【回溯】的方法,递归的方法不太容易想到.

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/219158.html原文链接:https://javaforall.net

(0)
上一篇 2025年7月8日 下午7:43
下一篇 2025年7月8日 下午8:15


相关推荐

  • Java 继承、多态与类的复用

    Java 继承、多态与类的复用本文结合Java的类的复用对面向对象两大特征继承和多态进行了全面的介绍。首先,我们介绍了继承的实质和意义,并探讨了继承,组合和代理在类的复用方面的异同。紧接着,我们根据继承引入了多态,介绍了它的实现机制和具体应用。此外,为了更好地理解继承和多态,我们对final关键字进行了全面的介绍。在此基础上,我们介绍了Java中类的加载及初始化顺序。最后,我们对面向对象设计中三个十分重要的概念-重载、覆盖与隐藏进行了详细的说明。

    2022年7月8日
    18
  • 26款 网络会议/视频会议开源软件

    26款 网络会议/视频会议开源软件转自:http://www.oschina.net/project/tag/227/video-conferencing?lang=0&os=0&sort=view&p=1视频

    2022年6月30日
    34
  • docker 常用命令大全

    docker 常用命令大全Docker常用命令大全

    2022年5月13日
    55
  • keras+resnet34实现车牌识别

    keras+resnet34实现车牌识别1.使用PIL和opencv生成车牌图像数据fromPILimportImageFont,Image,ImageDrawimportcv2importnumpyasnpimportosfrommathimport*#创建生成车牌图像数据的类index={“京”:0,”沪”:1,”津”:2,”渝”:3,”冀”:4,”晋”:5,”蒙”:6,”辽”:7,”吉”:8,”黑”:9,”苏”:10,”浙”:11,”皖”:12,

    2026年4月16日
    6
  • linux没有lsof命令

    linux没有lsof命令root rootbin lsof i 80 bash lsof commandnotfo 执行下面命令进行安装 yuminstallls 安装过程如图

    2026年3月18日
    0
  • HTML上传文件

    HTML上传文件文件上传表单 formaction method post enctype multipart form data div inputtype file multiple multiple accept image name image inputtype file multiple multiple accept image div div inputtype submit value 上传 inputtype submit value 上传 div formaction

    2026年3月20日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号