青蛙跳台阶(Fibonacci数列)
问题
一只青蛙一次可以跳上 1 级台阶,也可以跳上2 级。求该青蛙跳上一个n 级的台阶总共有多少种跳法。
思路
当n=1时,只有一种跳法,及f(1)=1,当n=2时,有两种跳法,及f(2)=2,当n=3时,可以从n=1直接跳到n=3,也可以从n=2直接跳到n=3,及f(3)=f(1)+f(2)=3...,所以可以使用递归,自顶向下,一步一步求解,但是仔细分析一下,如果n=10,需要求得f(9)和f(8),而f(9)=f(8)+f(7),f(8)=f(7)+f(6),可以很明显看到,求了重复的f(8)和f(7),随着n增大,这种复杂度是呈指数倍增长。
package offer009; import java.util.Scanner;
import java.util.concurrent.TimeUnit; /**
* @Title: Main.java
* @Package: offer009
* @Description 青蛙跳台阶,递归实现(计算量大)
* @author Han
* @date 2016-4-18 下午1:24:17
* @version V1.0
*/ public class Main { public static void main(String[] args) { Scanner scanner = new Scanner(System.in);
int n = 0; while(scanner.hasNext()){ n = scanner.nextInt();
//开始时的纳秒
long start = System.nanoTime();
long steps = getSteps(n);
//花费的纳秒数
long during = System.nanoTime() - start;
//将纳秒转换为毫秒
long seconds = TimeUnit.MILLISECONDS.convert(during, TimeUnit.NANOSECONDS); System.out.println(steps);
System.out.println("当n为" + n + "时,花费时间为" + seconds + "毫秒");
}
} private static long getSteps(int n) { if(n < 1)
throw new RuntimeException("Error Input"); if(n == 1)
return 1;
else if(n == 2)
return 2;
else
return getSteps(n - 1) + getSteps(n - 2);
}
}
测试
当n>40的时候,就会发现计算已经开始变慢了。
思路
另一种解法,子底向上方法,类似于动态规划,此次的结果为下回计算的使用,大量减少计算时间。
package offer009other; import java.util.Scanner;
import java.util.concurrent.TimeUnit; /**
* @Title: Main.java
* @Package: offer009other
* @Description 青蛙跳台阶,动态规划实现(计算量大)
* @author Han
* @date 2016-4-18 下午1:38:17
* @version V1.0
*/ public class Main { public static void main(String[] args) { Scanner scanner = new Scanner(System.in);
int n = 0; while(scanner.hasNext()){ n = scanner.nextInt();
//开始时的纳秒
long start = System.nanoTime();
long steps = getSteps(n);
//花费的纳秒数
long during = System.nanoTime() - start;
//将纳秒转换为毫秒
long seconds = TimeUnit.MILLISECONDS.convert(during, TimeUnit.NANOSECONDS); System.out.println(steps);
System.out.println("当n为" + n + "时,花费时间为" + seconds + "毫秒");
}
} private static long getSteps(int n) { long forgStepMinusOne = 2;
long forgStepMinusTwo = 1;
long steps = 0; for(int i = 3; i <= n; i++){ //当前n步有的跳法
steps = forgStepMinusOne + forgStepMinusTwo;
//为下一次的计算做准备,此次求得是n+1-2步的跳法个数
forgStepMinusTwo = forgStepMinusOne;
//为下一次的计算做准备,此次求得是n+1-1步的跳法个数
forgStepMinusOne = steps;
} return steps;
}
}
测试
总结
递归实现Fibonacci数列易懂,但是进行了太多的无谓的计算。
青蛙跳台阶(Fibonacci数列)的更多相关文章
- 【Java】 剑指offer(9) 斐波那契数列及青蛙跳台阶问题
本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集 题目 写一个函数,输入n,求斐波那契(Fibonacci)数列的第n项 ...
- [剑指offer]10.斐波那契数列+青蛙跳台阶问题
10- I. 斐波那契数列 方法一 Top-down 用递归实现 def fibonacci(n): if n <= 0: return 0 if n == 1: return 1 return ...
- 青蛙跳台阶问题——剑指offer
题目:一只青蛙一次可以跳上1级台阶,也可以跳上2级台阶,求该青蛙跳上一个n级台阶总共有多少中跳法. http://www.nowcoder.com/books/coding-interviews?pa ...
- Python算法题(一)——青蛙跳台阶
题目一(青蛙跳台阶): 一只青蛙一次可以跳上1级台阶,也可以跳上2级.求该青蛙跳上一个n级的台阶总共有多少种跳法. 分析: 假设只有一级台阶,则总共只有一种跳法: 假设有两级台阶,则总共有两种跳法: ...
- 【校招面试 之 剑指offer】第10-2题 青蛙跳台阶问题
题目1:一只青蛙一次可以跳上1级台阶,也可以跳上2级台阶.求该青蛙跳上一个n级台阶共有多少种跳法? 题目2:一只青蛙一次可以跳上1级台阶,也可以跳上2级台阶...也可以一次跳n级台阶.求该青蛙跳上一个 ...
- 面试书上一些题目的整理:O(n)复杂度排序年龄 & 青蛙跳台阶
可以按照年龄的个数,设置99个桶,然后桶内处理. 青蛙跳台阶,每次1阶或者2阶,就是fib数 如果每次1到n阶,那么归纳法可得,是2^(n-1) 另外1*2 覆盖 2*n个矩阵的问题,仍然是Fib数. ...
- 剑指 Offer 10- II. 青蛙跳台阶问题
剑指 Offer 10- II. 青蛙跳台阶问题 Offer 10- II 题目描述: 动态规划方程: 循环求余: 复杂度分析: package com.walegarrett.offer; impo ...
- 剑指offer-第二章算法之斐波拉契数列(青蛙跳台阶)
递归与循环 递归:在一个函数的内部调用这个函数. 本质:把一个问题分解为两个,或者多个小问题(多个小问题相互重叠的部分,会存在重复的计算) 优点:简洁,易于实现. 缺点:时间和空间消耗严重,如果递归调 ...
- 剑指offer 9-10:青蛙跳台阶与Fibonacii数列
题目描述 一只青蛙一次可以跳上1级台阶,也可以跳上2级.求该青蛙跳上一个n级的台阶总共有多少种跳法(先后次序不同算不同的结果). 问题分析 我们将跳法个数y与台阶数n视为一个函数关系,即y=f(n). ...
随机推荐
- 【Todo】Java新技术学习笔记-from某技术分析
看到这篇文章:http://mt.sohu.com/20160806/n462923089.shtml <十余年技术大牛告诉你,这些Java新技术不可错过> 虽然讲的比较泛,但是里面提到的 ...
- 详解zabbix安装部署(Server端篇)
原文:http://blog.chinaunix.net/uid-25266990-id-3380929.html Linux下常用的系统监控软件有Nagios.Cacti.Zabbix.Monit等 ...
- about shell
摘抄 cat 等 cat主要有三大功能:1.一次显示整个文件.$ cat filename2.从键盘创建一个文件.$ cat > filename只能创建新文件,不能编辑已有文件.3.将 ...
- spring data jpa 创建方法名进行简单查询
版权声明:本文为博主原创文章,未经博主允许不得转载. spring data jpa 可以通过在接口中按照规定语法创建一个方法进行查询,spring data jpa 基础接口中,如CrudRepos ...
- Javascript 弱类型:除法结果是小数
由于javascript是弱类型,只有一种var类型,所以在运算时不会自动强制转换,所以计算的结果是多少就是多少,但java中的17/10的结果就是1(强类型与弱类型)比如:console.log(M ...
- CTEX里的函数、符号及特殊字符
CTEX里的函数.符号及特殊字符 声调 语法 效果 语法 效果 语法 效果 \bar{a} \acute{a} \check{a} \grave{a} \tilde{a} \hat ...
- stdlib标准库的常用API
iOS 有如下四种随机数方法,下面以产生 [0,100) 的随机数为例: 1. srand((unsigned)time(0)); //不加这句每次产生的随机数不变 int i = rand() % ...
- Hbase之必要时取出请求的行(列族所有数据)
import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.hbase.CellScanner; import org. ...
- mialx配置qq邮箱发送邮件
#send mail use mailx(v12.0.4)#edit configure file set smtp-use-starttlsset from=xxxxxxxxx@qq.comset ...
- TWaver HTML5 (2D)----数据元素
概述 数据元素是数据模型的基本要素,用于描述图形网元,业务网元,或者纯数据.TWaver HTML5中所有数据元素都继承自twaver.Data.为不同功能的需求,预定义了三类数据类型:twaver. ...