假设有一只青蛙,每次可以跳一个台阶,也可以跳两个台阶,那么这只青蛙要跳上第n个台阶有多少种跳法。
根据以上分析,该问题类似于斐波那契数列,可以使用迭代的方式来计算青蛙跳上第n级台阶的跳法数。 初始条件:f(1)=1, f(2)=2。 迭代计算:从n=3开始,每次计算【 f(n)=f(n-1)+f(n-2) 】,直到计算到f(n)。
#include <stdio.h>
int jump(int n)
{
int a = 1;
int b = 2;
int result;
if (n <= 0)
{
return 0;
}
else if (n == 1)
{
return a;
}
else if (n == 2)
{
return b;
}
else
{
for (int i = 3; i <= n; i++)
{
result = a + b;//这样的赋值相当于一直在计算a + b,类似于斐波那契数列
a = b;
b = result;
}
return result;
}
}
int main()
{
int n;
printf("请输入台阶数:");
scanf("%d", &n);
printf("跳上 %d 个台阶共有 %d 种跳法。\n", n, jump(n));
return 0;
}