ZZULIOJ1091: 童年生活二三事(多实例测试)

斐波那契数列在台阶跳跃问题的应用
#include<stdio.h>
int main()/*解题思路:与之前的兔子生殖问题一样,原理都是斐波那契数列,
          一个台阶或两个台阶的走法分别是1、2,
		  三个台阶的走法有三种(走三个台阶,走一个台阶跳上两个台阶,跳上两个台阶走一个台阶),
		  由此可得后一项结果是前两项结果的和*/
{
	int a1,a2,a3,n,i;//a3为当前台阶跳法,i是循环变量
	//a1为第一个台阶跳法,后面对应两个台阶之前的跳法
	//a2为第二个台阶跳法,对应前一个台阶的跳法
	while(scanf("%d",&n),n!=0)//键盘读入台阶数n,n不为0时进入循环 
	{
	if(n==1)//一层台阶跳法是1
	printf("1\n");
	else if(n==2)//二层台阶跳法是2
	printf("2\n");
	else if(n>2)//当台阶数大于2的时候
	{
	a1=1,a2=2;//第一个前两种跳法分别是1,2
	for(i=3;i<=n;i++)//从第三个台阶开始计算
	{ 
	  a3=a1+a2;//下一个台阶等于之前两台阶跳法之和
	  a1=a2;//往前递推台阶
	  a2=a3;//同样递推
	}
	printf("%d\n",a3);//输出本次台阶数所对应的跳法
	}
	}
	return 0;//程序正常结束
 } 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值