第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

循環(huán)變量的Java斐波那契

循環(huán)變量的Java斐波那契

慕絲7291255 2022-06-04 16:57:32
這是一個(gè)程序,它接受一個(gè)命令行變量,將其解析為一個(gè) int,輸出是等于該 cmd 行參數(shù)的斐波那契數(shù)。所以如果我輸入 7,輸出將是 13。因?yàn)椋? 1 2 3 5 8 13 有人能解釋一下 b = a;在for循環(huán)里面?既然它們都已經(jīng)等于 1,為什么需要將它們?cè)O(shè)置為彼此相等呢?    int a,b,c;    int n = Integer.parseInt(args[0]);    a = 1;    b = 1;    c = 0;    if (n == 1 || n == 2)        System.out.println(1);    else     {        for (int i = 3; i<=n; i++)        {            c = a + b;            b = a;            a = c;        }        System.out.println(c);    }}
查看完整描述

2 回答

?
慕沐林林

TA貢獻(xiàn)2016條經(jīng)驗(yàn) 獲得超9個(gè)贊

a并且最初b等于 1 ,因此在循環(huán)的第一次迭代中,該語(yǔ)句什么也不做。但是讓我們看看在以后的迭代中會(huì)發(fā)生什么:


Initial state:

a = 1

b = 1

c = 0

Iteration 1:

c = 1 + 1 = 2

b = a = 1

a = c = 2

Iteration 2:

c = 1 + 2 = 3

b = a = 2

a = c = 3

Iteration 3:

c = 2 + 3 = 5

b = a = 3

a = c = 5

本質(zhì)上,a存儲(chǔ)序列中的前一個(gè)數(shù)字,而b存儲(chǔ)倒數(shù)第二個(gè)。由于序列的前 2 個(gè)數(shù)字是1, 1,b將在兩次迭代中保持為 1,但稍后會(huì)更改。


查看完整回答
反對(duì) 回復(fù) 2022-06-04
?
茅侃侃

TA貢獻(xiàn)1842條經(jīng)驗(yàn) 獲得超22個(gè)贊

Fn = Fn-1 + Fn-2,即從a = 1and開(kāi)始b = 1,您必須計(jì)算下一個(gè)斐波那契數(shù)并將 and 移動(dòng)a到b右邊的一個(gè)位置。


public static long fibonacci(int n) {

    n = Math.abs(n);


    if (n == 0)

        return 0;

    if (n < 3)

        return 1;


    long a = 1;

    long b = 1;

    long c = 0;


    for (int i = 3; i <= n; i++) {

        c = a + b;

        b = a;

        a = c;

    }


    return c;

}


查看完整回答
反對(duì) 回復(fù) 2022-06-04
  • 2 回答
  • 0 關(guān)注
  • 105 瀏覽
慕課專(zhuān)欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢(xún)優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)