前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >C++ 函数的递归调用

C++ 函数的递归调用

作者头像
chaibubble
发布2022-05-07 09:14:58
1.2K0
发布2022-05-07 09:14:58
举报
文章被收录于专栏:深度学习与计算机视觉

在调用一个函数的过程中又出现直接或间接地调用该函数本身,称为函数的递归(recursive)调用。包含递归调用的函数称为递归函数。 比如:

代码语言:javascript
复制
int test(int x)
{
	int y;
	y = test(x);
	return(2*y);
}

以上是一个直接调用的例子,递归调用还包括间接调用,比如:

代码语言:javascript
复制
int first(int x)
{
	int b;
	b = second(x);
	return(2*b);
}
int second(int y)
{
	int a;
	a = first(y);
	return(2*a);
}

从上面的程序可以看到,这样执行后会出现无终止的自身调用,所以程序应该加入对用的判断机制,让递归在有限次数后停止。

举个栗子: 用递归的方式求n!

代码语言:javascript
复制
#include <iostream>
using namespace std;
long fac(int);
int main()
{
	int n;
	long y;
	cout <<"请输入";
	cin >>n;
	y = fac(n);
	cout<<n<<"!="<<y<<endl;
	getchar();
	getchar();
	return 0 ;
}

long fac(int n)
{
	long f;
	if (n <0)
	{
		cout<<"错误!!!"<<endl;
	}
	else if(n== 0||n == 1) 
	f =1;
	else 
	f=fac(n-1)*n;
	return f;
}
这里写图片描述
这里写图片描述

递归退出的条件:

代码语言:javascript
复制
	else if(n== 0||n == 1) 
	f =1;

如果n等于0或者等于1,那么执行f等于1,不在调用fac函数,退出了递归。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017-02-06,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档