用C简单实现factorial(阶乘)算法

//实现factorial(阶乘)算法
#include <stdio.h>
void main()
{
	int factorial_rec(int a);
	int factorial_iter(int b);
	int s;
	printf("请输入一个数字:");
	scanf("%d", &s);
	printf("使用递归:%d", factorial_rec(s));
	printf("\n使用迭代:%d", factorial_iter(s));
}

//使用递归  ---  递归容易造成栈溢出,要谨慎使用 
int factorial_rec(int a) {
	if (a > 1) {
		return a * factorial_rec(a - 1);
	} else {
		return 1;
	}
}

//使用迭代 --- 迭代堆空间要求没递归苛刻,但是逻辑算法没有递归简单明了
int factorial_iter(int b) {
	int i, s = 1;
	if (b) {
		for (i=1; i<=b; i++) {
			s *= i;	
		}
	}
	return s;
}

使用c语言简单实现阶乘算法

  • 3
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值