一.递归的两个必要条件:
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;
}