为了账号安全,请及时绑定邮箱和手机立即绑定

循环变量的Java斐波那契

循环变量的Java斐波那契

慕丝7291255 2022-06-04 16:57:32
这是一个程序,它接受一个命令行变量,将其解析为一个 int,输出是等于该 cmd 行参数的斐波那契数。所以如果我输入 7,输出将是 13。因为:1 1 2 3 5 8 13 有人能解释一下 b = a;在for循环里面?既然它们都已经等于 1,为什么需要将它们设置为彼此相等呢?    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贡献2016条经验 获得超9个赞

a并且最初b等于 1 ,因此在循环的第一次迭代中,该语句什么也不做。但是让我们看看在以后的迭代中会发生什么:


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

本质上,a存储序列中的前一个数字,而b存储倒数第二个。由于序列的前 2 个数字是1, 1,b将在两次迭代中保持为 1,但稍后会更改。


查看完整回答
反对 回复 2022-06-04
?
茅侃侃

TA贡献1842条经验 获得超21个赞

Fn = Fn-1 + Fn-2,即从a = 1and开始b = 1,您必须计算下一个斐波那契数并将 and 移动a到b右边的一个位置。


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;

}


查看完整回答
反对 回复 2022-06-04

添加回答

代码语言

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号