C语言 求阶乘和

法一:利用for循环

输入n 后,我们要计算1!+2!+...+n!,我们最容易想到的,也会写的是某单个数的循环,如

int n = 5; //当输入n = 5时
int i = 0;
int num = 1;//循环总和
int renum = 0;//累加总和
for(i = 1; i <= n; i++) // 5 的阶乘 1 * 2 * 3 * 4 * 5
{
    num *= i;
}

       那么对于一系列的阶乘(如标题),我们可以这样来看:以输入n = 5为例,5!进行循环之后将5减去1即可再次进行4!的循环,因此,我们可以利用2层for循环来实现标题所求.将上段代码作为内层, 外层for循环实现 n - 1的操作,代码如下:

//不全代码
for(int i = n; i >= 1; i--)<1
	{
		for(int j = 1; j <= n; j++)
		{
			num *= j;
		}
		n--;//n减一次
		renum += num;对总和累加 
	}

<1:实现5! *4! *...*1!,能不能for(i = 1; i <= n; i++)?你可以试一试.

那么上述代码是否实现我们的目标呢?我们来走一遍代码:输入n = 5时,i = 5, j = 1;num = 1 * 1,j++,j = 2, num = 1 * 1 * 2, 以下类推, renum += num = 120;当n-- = 4时,i = 4, j = 1, num = 120 * 1,有问题了, num不在是从1开始,因此,我们这样修改代码,如下:

int n = 0;
	//int num = 1;
	int renum = 0;
	scanf("%d", &n);
	
	for(int i =n; i >= 1; i--)
	{
		int num = 1;
		for(int j = 1; j <= n; j++)
		{
			num *= j;
		}
		n--; 
	}

 完整代码如下:

#include<stdio.h>

int main(void)
{
	int n = 0;
	//int num = 1;
	int renum = 0;
	scanf("%d", &n);
	
	for(int i =n; i >= 1; i--)
	{
		int num = 1;
		for(int j = 1; j <= n; j++)
		{
			num *= j;
		}
		n--;
		renum += num;
	}
	
	printf("%d", renum);
	
	return 0;
}

法二:利用递归

      程序调用自身的编程技巧称为递归( recursion)。递归做为一种算法程序设计语言中广泛应用。 一个过程或函数在其定义或说明中有直接或间接调用自身的一种方法,它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量。递归的能力在于用有限的语句来定义对象的无限集合。一般来说,递归需要有边界条件、递归前进段和递归返回段。当边界条件不满足时,递归前进;当边界条件满足时,递归返回。----摘自 百度百科.

  自定义函数fac();如下:

	int n = 0;
	scanf("%d", &n);
	int renum = fac(n);//接收值
	printf("%d", renum);

函数fac()代码如下

int fac(int n)
{
	int num = 1;
	if(n >= 0)<2
	{
		for(int i = 1; i <= n; i++)
		{
			num *= i;
		}
		return num + fac(n - 1);<3
	}
	return -1;<4
}

<2:递归需要有边界条件,即什么时候结束

<3这个代码是如何走的?

 <3:为什么返回-1呢?int num = 1时多加了1;

完整代码如下;

#include<stdio.h>

int fac(int n)
{
	int num = 1;
	if(n >= 0)
	{
		for(int i = 1; i <= n; i++)
		{
			num *= i;
		}
		return num + fac(n - 1);
	}
	return -1;
}

int main(void)
{
	int n = 0;
	scanf("%d", &n);
	int renum = fac(n);
	printf("%d", renum);
	
	return 0;
}

  • 25
    点赞
  • 111
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值