成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

斐波那契數(shù)列(求fibonacci的第N項(xiàng)的值)

Fundebug / 2744人閱讀

摘要:今天在公司實(shí)習(xí),實(shí)在沒啥活是我能干的,就想著寫一寫算法打發(fā)時(shí)間,正好看到了斐波那契數(shù)列,搞起。這是斐波那契數(shù)列的通項(xiàng)公式以前用遞歸寫過,今天看的時(shí)候書上說遞歸雖然簡(jiǎn)單,但其實(shí)內(nèi)部做了很多重復(fù)的計(jì)算,而且尾遞歸都是可以用循環(huán)解決的。

今天在公司實(shí)習(xí),實(shí)在沒啥活是我能干的,就想著寫一寫算法打發(fā)時(shí)間,正好看到了斐波那契數(shù)列,搞起。

這是斐波那契數(shù)列的通項(xiàng)公式:

以前用遞歸寫過,今天看的時(shí)候書上說遞歸雖然簡(jiǎn)單,但其實(shí)內(nèi)部做了很多重復(fù)的計(jì)算,而且尾遞歸都是可以用循環(huán)解決的。而用循環(huán)就可以避免重復(fù)的計(jì)算。

import java.util.Scanner;

public class Jianzhi{

    public static void main (String[] args){
        Scanner scanner = new Scanner(System.in);
        int n = scanner.nextInt();
        n = fibonacci(n) ;
        System.out.println(n) ;
    }
    public static int fibonacci(int n ) {

        int f0 = 0;
        int f1 = 1;
        int fn = 0 ;
        if (n == 0) {
            return f0;
        }
        if (n == 1) {
            return f1;
        } else {
            for (int i = 2; i <= n; i++) {
                fn = f0 + f1;  //當(dāng)前循環(huán)所得的斐波那契數(shù)等于前一個(gè)加上前前個(gè)
                f0 = f1 ;     //當(dāng)前循環(huán)所得的斐波那契數(shù)的前一個(gè)數(shù),作為下次循環(huán)的前前個(gè)次數(shù)
                f1 = fn ;     //當(dāng)前循環(huán)所得的斐波那契的數(shù),作為下次循環(huán)的前一個(gè)數(shù)
            }
            return fn;
        }
    }

}

斐波那契數(shù)列的變換:
比如,從前有一只青蛙,它一次可以跳一個(gè)臺(tái)階,也可以一次跳兩個(gè)臺(tái)階,求一個(gè)N階的臺(tái)階他會(huì)用幾種跳法。

那就是假設(shè)就1個(gè)臺(tái)階 那就只有1種跳法;如果有2個(gè)臺(tái)階,那就有2種;以此類推:

  1    1
  2    2
  3    3
  4    5

完畢。

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/71370.html

相關(guān)文章

  • 斐波那契數(shù)列和的js方案以及優(yōu)化

    摘要:在上做了一道斐波那契數(shù)列求和的題目,做完之后做了一些簡(jiǎn)單的優(yōu)化和用另一種方法實(shí)現(xiàn)。動(dòng)態(tài)規(guī)劃解決方案斐波那契數(shù)列求和除了可以用遞歸的方法解決,還可以用動(dòng)態(tài)規(guī)劃的方法解決。 在codewars上做了一道斐波那契數(shù)列求和的題目,做完之后做了一些簡(jiǎn)單的優(yōu)化和用另一種方法實(shí)現(xiàn)。 題目 function fibonacci(n) { if(n==0 || n == 1) r...

    xinhaip 評(píng)論0 收藏0
  • js 實(shí)現(xiàn)斐波那契數(shù)列(數(shù)組緩存、動(dòng)態(tài)規(guī)劃、尾調(diào)用優(yōu)化)

    摘要:根據(jù)該規(guī)則,返回第個(gè)斐波那契數(shù)。尾遞歸函數(shù)調(diào)用自身,稱為遞歸。一個(gè)前端眼中的斐波那契數(shù)列解斐波那契數(shù)列的實(shí)用解法調(diào)用棧尾遞歸和手動(dòng)優(yōu)化尾調(diào)用優(yōu)化譯我從用寫斐波那契生成器中學(xué)到的令人驚訝的件事 斐波那契數(shù)列是以下一系列數(shù)字: 0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, 233, 377, 610, 987, ... 在種子數(shù)字 0 和 1 ...

    趙連江 評(píng)論0 收藏0
  • JavaScript解斐波那契(Fibonacci)數(shù)列的實(shí)用解法

    摘要:下面是一個(gè)可以處理很多類型遞歸函數(shù)的函數(shù)其中第一個(gè)參數(shù)為原有函數(shù),第二個(gè)參數(shù)為緩存對(duì)象,是可選參數(shù)因?yàn)椴⒉皇撬羞f歸函數(shù)都包含初始信息。首先將緩存對(duì)象的類型從數(shù)組轉(zhuǎn)換為對(duì)象,這樣就可以適用于那些不是返回整數(shù)的遞歸函數(shù)。 JavaScript解斐波那契(Fibonacci)數(shù)列的實(shí)用解法 我們經(jīng)常會(huì)在面試題中看到如下題目:輸入n,求斐波那契數(shù)列的第n項(xiàng),斐波那契數(shù)列的定義如下: F(0)...

    zhongmeizhi 評(píng)論0 收藏0
  • 【刷算法】斐波那契數(shù)列

    摘要:題目現(xiàn)在要求輸入一個(gè)整數(shù),請(qǐng)你輸出斐波那契數(shù)列的第項(xiàng)。遞歸操作時(shí)間復(fù)雜度太高,而且用遞歸會(huì)產(chǎn)生很多重復(fù)的操作。非遞歸操作這種方法就是一次遍歷過去就行,計(jì)算第個(gè)數(shù)時(shí),使用了兩個(gè)變量存儲(chǔ)第和第個(gè)數(shù),使時(shí)間復(fù)雜度降低到 題目 現(xiàn)在要求輸入一個(gè)整數(shù)n,請(qǐng)你輸出斐波那契數(shù)列的第n項(xiàng)。 遞歸操作O(2^n) function fibonacci(n) { if(n < 1) ...

    IamDLY 評(píng)論0 收藏0
  • JS專題之memoization

    摘要:前言在計(jì)算機(jī)領(lǐng)域,記憶是主要用于加速程序計(jì)算的一種優(yōu)化技術(shù),它使得函數(shù)避免重復(fù)演算之前已被處理過的輸入,而返回已緩存的結(jié)果。被執(zhí)行了不是素?cái)?shù),其他數(shù)字默認(rèn)是素?cái)?shù)。我們可以看出,如果從開始打印斐波那契數(shù)列,函數(shù)被執(zhí)行了次。 前言 在計(jì)算機(jī)領(lǐng)域,記憶(memoization)是主要用于加速程序計(jì)算的一種優(yōu)化技術(shù),它使得函數(shù)避免重復(fù)演算之前已被處理過的輸入,而返回已緩存的結(jié)果。 -- wi...

    zhisheng 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<