计蒜客——难题库——“爬梯子”问题
2015-11-05 13:46
429 查看
问题描述:
假设你现在正在爬楼梯,楼梯有n级。每次你只能爬1级或者2级,那么你有多少种方法爬到楼梯的顶部?
格式:
第一行输入一个数n(n<=50),代表楼梯的级数。
接下来一行输出你的方法总数。
例如:
输入 5
输出 8
原题链接:http://nanti.jisuanke.com/t/16
问题分析:
这个问题的实质是求解斐波那契数列中指定位置的数值,
解决方案有以下几种:
一、递归方式
设计思路:联想到二叉树的形状跟本题极为相似,因此有以下代码;
例如
4
3 2
1 2 1 0
0 1 0 0
0
#include<iostream>
using namespace std;
int recursion(int num,int m)
{
if(num-1>=0)
{
if(num-1==0)
m+=1;
else
{
int temp=num-1;
m=recursion(temp,m);
}
}
if(num -2>=0)
{
if(num-2==0)
m+=1;
else
{
int temp2=num-2;
m=recursion(temp2,m);
}
}
return m;
}
int main()
{
int n;
cin>>n;
int method=0;//方法数
int sum=0;
method=Tree(n,sum);
cout<<method;
return 0;
}
二、 递归方式二
设计思路:根据斐波那契数列的递推式得出的
T(n+1)=T(n)+T(n-1);
递推结束条件:n=1 时T(n)=1,n=2 时T(n)=2
#include<iostream>
using namespace std;
int recursion(int num)
{
if(num>2)
{
return recursion(num-1)+recursion(num-2);
}
if(num==1)
{
return 1;
}
if(num==2)
{
return 2;
}
}
int main()
{
int n;
cin>>n;
cout<<recursion(n);
return 0;
}
三、预先生成斐波那契数列,再根据所输入的数字输出对应的值
设计思路:随着递归的层数增加,递归次数变得越来越大,因此上述两种方式在运行时都超时了,不满足题目的要求。因此可以先生成一个斐波那契数列,再按照输入的数据输出对应的值。
int main()
{
long int result[100];//用于存储已经计算过的结果
result[0]=1;
result[1]=2;
int n;
cin>>n;
int temp=0;
while(temp<51)
{
if(temp>1)
{
result[temp]=result[temp-1]+result[temp-2];
}
temp+=1;
}
cout<<result[n-1];
return 0;
}
结束语:虽然第三种方法通过了,但是由于未系统的了解算法的知识,对于他所考察的动态规划似乎没有考虑,只能日后再完善了。
假设你现在正在爬楼梯,楼梯有n级。每次你只能爬1级或者2级,那么你有多少种方法爬到楼梯的顶部?
格式:
第一行输入一个数n(n<=50),代表楼梯的级数。
接下来一行输出你的方法总数。
例如:
输入 5
输出 8
原题链接:http://nanti.jisuanke.com/t/16
问题分析:
这个问题的实质是求解斐波那契数列中指定位置的数值,
解决方案有以下几种:
一、递归方式
设计思路:联想到二叉树的形状跟本题极为相似,因此有以下代码;
例如
4
3 2
1 2 1 0
0 1 0 0
0
#include<iostream>
using namespace std;
int recursion(int num,int m)
{
if(num-1>=0)
{
if(num-1==0)
m+=1;
else
{
int temp=num-1;
m=recursion(temp,m);
}
}
if(num -2>=0)
{
if(num-2==0)
m+=1;
else
{
int temp2=num-2;
m=recursion(temp2,m);
}
}
return m;
}
int main()
{
int n;
cin>>n;
int method=0;//方法数
int sum=0;
method=Tree(n,sum);
cout<<method;
return 0;
}
二、 递归方式二
设计思路:根据斐波那契数列的递推式得出的
T(n+1)=T(n)+T(n-1);
递推结束条件:n=1 时T(n)=1,n=2 时T(n)=2
#include<iostream>
using namespace std;
int recursion(int num)
{
if(num>2)
{
return recursion(num-1)+recursion(num-2);
}
if(num==1)
{
return 1;
}
if(num==2)
{
return 2;
}
}
int main()
{
int n;
cin>>n;
cout<<recursion(n);
return 0;
}
三、预先生成斐波那契数列,再根据所输入的数字输出对应的值
设计思路:随着递归的层数增加,递归次数变得越来越大,因此上述两种方式在运行时都超时了,不满足题目的要求。因此可以先生成一个斐波那契数列,再按照输入的数据输出对应的值。
int main()
{
long int result[100];//用于存储已经计算过的结果
result[0]=1;
result[1]=2;
int n;
cin>>n;
int temp=0;
while(temp<51)
{
if(temp>1)
{
result[temp]=result[temp-1]+result[temp-2];
}
temp+=1;
}
cout<<result[n-1];
return 0;
}
结束语:虽然第三种方法通过了,但是由于未系统的了解算法的知识,对于他所考察的动态规划似乎没有考虑,只能日后再完善了。
相关文章推荐
- 使用C++实现JNI接口需要注意的事项
- 关于指针的一些事情
- c++ primer 第五版 笔记前言
- share_ptr的几个注意点
- Lua中调用C++函数示例
- Lua教程(一):在C++中嵌入Lua脚本
- Lua教程(二):C++和Lua相互传递数据示例
- C++联合体转换成C#结构的实现方法
- C++编写简单的打靶游戏
- C++ 自定义控件的移植问题
- C++变位词问题分析
- C/C++数据对齐详细解析
- C++基于栈实现铁轨问题
- C++中引用的使用总结
- 使用Lua来扩展C++程序的方法
- C++中调用Lua函数实例
- Lua和C++的通信流程代码实例
- C与C++之间相互调用实例方法讲解
- 解析C++中派生的概念以及派生类成员的访问属性
- C++ Custom Control控件向父窗体发送对应的消息