509. 斐波那契数

斐波那契数,通常用 F(n) 表示,形成的序列称为斐波那契数列。该数列由 0 和 1 开始,后面的每一项数字都是前面两项数字的和。也就是:

F(0) = 0, F(1) = 1

F(N) = F(N - 1) + F(N - 2), 其中 N > 1.

给定 N,计算 F(N)。

示例 1:

输入:2

输出:1

解释:F(2) = F(1) + F(0) = 1 + 0 = 1.

示例 2:

输入:3

输出:2

解释:F(3) = F(2) + F(1) = 1 + 1 = 2.

示例 3:

输入:4

输出:3

解释:F(4) = F(3) + F(2) = 2 + 1 = 3.

提示:

0 ≤ N ≤ 30

PS:

第一个比较简单,

第二个是用黄金分割求斐波那契

第三个是矩阵求斐波那契

class Solution {
public int fib(int N) {
// if (N == 0 || N == 1) {
// return N;
// }
// int x = 0,y = 1,z = 1,i = 0,end = N-2;
// while (i <= end) {
// z = x + y;
// x = y;
// y = z;
// i++;
// }
// return z; // double goldenRatio = (1 + Math.sqrt(5)) / 2;
// return (int)Math.round(Math.pow(goldenRatio, N)/ Math.sqrt(5)); if (N <= 1) {
return N;
}
int[][] A = new int[][]{{1, 1}, {1, 0}};
matrixPower(A, N-1);
return A[0][0];
} void matrixPower(int[][] A, int N) {
if (N <= 1) {
return;
}
matrixPower(A, N/2);
multiply(A, A); int[][] B = new int[][]{{1, 1}, {1, 0}};
if (N%2 != 0) {
multiply(A, B);
}
} void multiply(int[][] A, int[][] B) {
int x = A[0][0] * B[0][0] + A[0][1] * B[1][0];
int y = A[0][0] * B[0][1] + A[0][1] * B[1][1];
int z = A[1][0] * B[0][0] + A[1][1] * B[1][0];
int w = A[1][0] * B[0][1] + A[1][1] * B[1][1]; A[0][0] = x;
A[0][1] = y;
A[1][0] = z;
A[1][1] = w;
} }

最新文章

  1. iOS项目开发中的知识点与问题收集整理②(Part 二)
  2. Python的第三天
  3. HBase读延迟的12种优化套路
  4. Seen.js – 使用 SVG 或者 Canvas 渲染 3D 场景
  5. 在ubuntu14.04上安装编译Android需要的开发包
  6. 【BZOJ】2084: [Poi2010]Antisymmetry
  7. Asp.net设计模式笔记之三:业务逻辑层的组织
  8. CSS浏览器兼容的那些事儿
  9. 20145129 《Java程序设计》第6周学习总结
  10. [转]Linux之od命令
  11. POJ 2362 Square
  12. jdbc批量插入
  13. Python 字典和集合基于哈希表实现
  14. 使用PHP做分页查询(查询结果也显示为分页)
  15. PAT乙级考前总结(三)
  16. Ubuntu18.04安装mysql5.7
  17. activiti 快速入门--组任务(candidate users)分配(6)
  18. Windows 10 将MySQL5.5升级为MySQL5.7
  19. Ex 6_14 布料剪裁问题_第八次作业
  20. yum-阿里源配置

热门文章

  1. STM32 IAP 升级官方资料汇总
  2. spring data jpa 多对多 ManyToMany
  3. R语言:日薪和应发工资
  4. 帝国cms列表页内容简介字段smalltext去除里面html格式代码 设置方法
  5. layui批量传值到后台操作时出现传值为空的问题
  6. Android CodeReview 些许总结
  7. 初识spring boot maven管理--SpringMVC
  8. jsp 中文乱码????解决
  9. 【SMB源码解析系列】——001.JumpEngine函数
  10. Sentinel源码解析四(流控策略和流控效果)