码迷,mamicode.com
首页 > 其他好文 > 详细

Fibonacci Number LT509

时间:2019-04-05 09:18:29      阅读:223      评论:0      收藏:0      [点我收藏+]

标签:dea   ide   number   nat   ber   min   code   not   style   

The Fibonacci numbers, commonly denoted F(n) form a sequence, called the Fibonacci sequence, such that each number is the sum of the two preceding ones, starting from 0 and 1. That is,

F(0) = 0,   F(1) = 1
F(N) = F(N - 1) + F(N - 2), for N > 1.

Given N, calculate F(N).

 

Example 1:

Input: 2
Output: 1
Explanation: F(2) = F(1) + F(0) = 1 + 0 = 1.

Example 2:

Input: 3
Output: 2
Explanation: F(3) = F(2) + F(1) = 1 + 1 = 2.

Example 3:

Input: 4
Output: 3
Explanation: F(4) = F(3) + F(2) = 2 + 1 = 3.

Note:

0 ≤ N ≤ 30.

 

Idea 1. dynamic programming, 经典的入门dp,
dp[i] = dp[i-2] + dp[i-1] (i >= 2)
Time complexity: O(n)
Space complexity: O(n)
 1 class Solution {
 2     public int fib(int N) {
 3        if(N <= 1) {
 4            return N;
 5        }
 6         
 7         int[] dp = new int[N+1];
 8         dp[0] = 0;
 9         dp[1] = 1;
10         
11         for(int i = 2; i <= N; ++i) {
12             dp[i] = dp[i-1] + dp[i-2];
13         }
14         
15         return dp[N];
16     }
17 }

Idea 1.b, 从上面的公式可以看出只需要前2位dp[i-2] and dp[i-1], 可以不用array dp[].

Time complxity: O(n)

Space complexity: O(1)

 1 class Solution {
 2     public int fib(int N) {
 3         int first = 0;
 4         int second = 1;
 5         int result = N;
 6         
 7         for(int i = 2; i <= N; ++i) {
 8             result = first + second;
 9             first = second;
10             second = result;
11         }
12         
13         return result;
14     }
15 }

 

Fibonacci Number LT509

标签:dea   ide   number   nat   ber   min   code   not   style   

原文地址:https://www.cnblogs.com/taste-it-own-it-love-it/p/10657874.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!