【面试题】N阶台阶的走法种数问题(分支思想)
2017-03-02 16:32
232 查看
【面试题】N阶台阶的走法种数问题(分支思想)
【面试题】在一些技术面试中,经常会有N阶台阶每次走一步或两步,问有多少种走法的题目,实际上就是斐波那契数列算法,在此本人通过分支思想进行统计方法数。一、题目重述
总共有100阶台阶,每次走一步或两步,请问共有几种走法?
二、解决方案
可以模拟树分支的思想,通过for循环将每次选择一步或者两步的走法以分支形式分开,并将剩下的阶数(stair - i)作为参数进入递归,当stair为0,即到分支末,统计分支数,即可得方法数。
三、代码实现
#include <iostream> using namespace std; const int Stair = 100; //台阶数 static int num = 0; //统计方法数 void Add_up(int stair){ if (0 == stair || 1 == stair)//当stair为0,表示已到分支末;当stair为1,为避免stair - i出现小于0的情况,在此特意选出来 { num++; return; } for (int i = 1; i <= 2; i++)//每次可选择走一步或两布,根据选择不同划出分支 Add_up(stair - i);//减去所走步数,进入新的递归 } void main() { Add_up(Stair); cout << "共有" << num << "种走法" << endl; }
四、结束语
类似可以走一步或两步或三步的题目,可以参考上述代码修改for循环 i 的最大值和注意(stair - i)的值小于0的情况即可。
希望对大家有帮助。
相关文章推荐
- 程序员面试题100题第23题——跳台阶问题
- 程序员面试题100题第23题——跳台阶问题
- 程序员面试题精选100题(23)-跳台阶问题
- 面试题整理-台阶问题
- JS面试题---关于算法台阶的问题
- JS面试题-算法台阶问题
- 剑指offer面试题9 斐波那契数列及青蛙跳台阶问题
- 面试题经典:跳台阶问题
- 剑指offer面试题9-青蛙跳台阶及其变种问题
- 面试题:青蛙跳台阶问题
- 递归分支的思想求最近对问题
- 斐波那契数列——腾讯面试题台阶问题
- 程序员面试题精选100题(23)-跳台阶问题
- 23. 微软面试题:跳台阶问题
- 面试题之青蛙变态跳台阶问题
- 【我解C语言面试题系列】005 按位反转字符问题
- 面试题之苹果问题
- 一个Hibernate 的面试题, 现场分析问题
- 【我解C语言面试题系列】004 数组的循环右移问题
- 【我解C语言面试题系列】006 按位反转整数问题