递归与迭代

一.递归的两个必要条件:
1.存在限制条件,当满足这个限制条件的时候,递归便不再继续。
2.每次递归调用之后越来越接近这个限制条件。
二.迭代与循环的关系:迭代>=循环
练习:求n的阶乘(递归)
笔记:如果n<=1,阶乘为1;如果n>1,阶乘为n*(n-1)!

#include<stdio.h>
int Fac(int m)
{
	if (m<= 1)
	{
		return 1;//如果m<=1,阶乘为1
	}
	else
	{
		return m * Fac(m-1);//如果m>1,阶乘为n*(n-1)!
	}
}
int main()
{
	int n = 0;
	int ret = 0;
	scanf_s("%d", &n);
	ret = Fac(n);//递归函数用ret接收
	printf("%d\n", ret);
	return 0;
}

练习:求第n个斐波那契数。(不考虑溢出)(递归:效率低)
规律:前2个数相加等于第3个数
笔记:如果n<=2,第m个斐波那契数为1;如果n>2,第m个斐波那契数为Fib(n-1)+Fib(n-2)

#include<stdio.h>
int Fib(int m)
{
	//如果m<=2,第m个斐波那契数为1
	if (m <= 2)
	{
		return 1;
	}
	//如果m>2,第m个斐波那契数为Fib(n-1)+Fib(n-2)
	else
	{
		return Fib(m - 1) + Fib(m - 2);
	}
}
int main()
{
	int n = 0;
	int ret = 0;
	scanf_s("%d", &n);
	ret = Fib(n);//递归函数用ret接收
	printf("%d\n", ret);
	return 0;
}

练习:求第n个斐波那契数。(不考虑溢出)(非递归:效率高)

#include<stdio.h>
int Fib(int m)
{
	int a = 1;
	int b = 1;
	int c = 1;
	while (m > 2)
	{
		c = a + b;
		a = b;
		b = c;
		m--;
	}
	return c;
}
int main()
{
	int n = 0;
	int ret = 0;
	scanf_s("%d", &n);
	ret = Fib(n);//递归函数用ret接收
	printf("%d\n", ret);
	return 0;
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值