【剑指Offer面试题】 九度OJ1389:变态跳台阶
来源:互联网 发布:看动漫学日语软件 编辑:程序博客网 时间:2024/04/28 05:38
题目链接地址:
http://ac.jobdu.com/problem.php?pid=1389
题目1389:变态跳台阶
时间限制:1 秒内存限制:32 兆特殊判题:否提交:2331解决:1332
题目描述:
一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级。求该青蛙跳上一个n级的台阶总共有多少种跳法。
输入:
输入可能包含多个测试样例,对于每个测试案例,
输入包括一个整数n(1<=n<=50)。
输出:
对应每个测试案例,
输出该青蛙跳上一个n级的台阶总共有多少种跳法。
样例输入:
6
样例输出:
32
思路分析:
青蛙跳上n级台阶的跳法情况(f(n)),第一次跳的时候:
(1) 选择跳上1级台阶,那么还剩下n - 1级台阶,而跳上n – 1级台阶的跳法数目是f(n - 1);
(2) 选择跳上2级台阶,那么剩下n - 2级台阶,而跳上n – 2级台阶的跳法数目是f(n - 2)。
(3)选择跳上3级台阶,剩下n - 3台阶, 而跳上n –3级台阶的跳法数目是f(n - 3)。
……
所以总数为f(n) = f(n-1) + f(n-2) + … + f(2) + f(1) + f(0).
f(n-1)= f(n-2) + … + f(2) + f(1) + f(0)
两式相减得:
f(n) =2f(n-1)
f(1)=1
对于f(0).通过f(2)=f(1)+f(0)=2知道 f(0)=1.
参考前一篇博文。
代码:
/********************************* ----------------------------------- 【剑指Offer面试题】 九度OJ1389:变态跳台阶----------------------------------- Author:牧之丶 Date:2015年Email:bzhou84@163.com **********************************/ #include<stdio.h>#include<string>#include<stack>#include <iostream>using namespace std;#define N 55long long jumpNum[N]; long long JumpNum(int n){ int i; jumpNum[0] = 1; jumpNum[1] = 1; for(i = 2;i <= n;i++) { jumpNum[i] = 2*jumpNum[i - 1]; } return jumpNum[n];}int main(){ int n; while(scanf("%d",&n)!=EOF) { printf("%lld\n",JumpNum(n)); // long long 输出为 lld } return 0;}/************************************************************** Problem: 1389 Language: C++ Result: Accepted Time:0 ms Memory:1520 kb****************************************************************/
1 0
- 【剑指Offer面试题】 九度OJ1389:变态跳台阶
- 九度OJ1389剑指offer面试题9变形:变态跳台阶
- 【剑指offer】面试题:变态跳台阶
- 剑指offer面试题之变态跳台阶
- 剑指offer之面试题9-3:变态跳台阶
- 剑指offer面试题[9-2]-变态跳台阶
- 【剑指Offer面试题】 九度OJ1388:跳台阶
- 剑指offer(九)变态跳台阶
- 九度1389 剑指offer 变态跳台阶
- [九度OnlineJudge][剑指Offer]题目1389:变态跳台阶
- 剑指offer 面试题9 斐波那契数列/青蛙跳台阶/矩形覆盖/变态跳台阶
- 【剑指offer】变态跳台阶
- 【剑指offer】变态跳台阶
- 剑指offer :变态跳台阶
- 剑指Offer-变态跳台阶
- 《剑指offer》变态跳台阶
- 【剑指Offer】变态跳台阶
- 剑指offer--变态跳台阶
- Big Number
- 渗透测试工具介绍
- LVM的用法
- HDU - 1711 - Number Sequence,1686 - Oulipo,2087 - 剪花布条,3746 - Cyclic Nacklace (KMP基础)
- unicode下CString转string
- 【剑指Offer面试题】 九度OJ1389:变态跳台阶
- 你刚才在淘宝上买了一件东西---Ბ来自阿里员工卡特
- 2015生活中的点滴随想
- int&boolean——Java和C的一点小区别
- php中堆栈调试
- [黑马程序员](第9天)面向对象小结
- [精通iOS开发(第5版)]第16章 使用Quartz和OpenGL绘图 笔记
- birt脚本调试方法
- Oracle备份与恢复介绍(物理备份与逻辑备份)