[ACM入门] 青蛙跳台阶问题

本题由一个学弟提供,之前选拔ACM队员的练习题。

0. 题干

一只小青蛙,每次跳台阶,他可以一下跳一个台阶,或者两个台阶,问假设有n个台阶,这只青蛙一共有多种跳的方法

1. 分析解决

列出一个台阶,1种方法;两个台阶,2种方法;

3个台阶的时候,青蛙可以从第一个台阶跳上去,也可以从第二个台阶跳上去,所以等于1+2=3;

依次类推s(n)=s(n-1)+s(n-2) (n>2)

发现是一个斐波纳挈数列;

代码如下:

#include<iostream>
#include<algorithm>  
using namespace std;
 
int forge(int n){  
    if( n <=0)
		return 0;
	if (n ==1)
		return 1;
	if (n == 2)
		return 2;
	if ( n>2)
		return forge(n-1)+forge(n-2);
    
    return -1;// 避免函数找不到,编译器给warning
}
 
int main(){
    int n;
	double ret= -1;
    cin>>n;
	cout<<"请输入台阶数量 :"<<n;

    cout<<endl;

	ret=forge(n);
    
	if (ret){
		cout<< "青蛙可以跳的方法有:";
		cout << ret;
		cout << " 种 " << endl;
	}

	else{
		cout<< "请重新输入正确的n值" << endl;

	}
    return 0;

}

运行3:

在这里插入图片描述

运行4:

在这里插入图片描述

运行10:

在这里插入图片描述

这个递归的时间复杂度很大,随着n值的递增,最终的结果也会很大;

可参考我的这篇数学证明:斐波那契数列重要不等式证明

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值