剑指offer—斐波那契数列

题目描述
大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项。
n<=39
题目思路
该题考的是斐波拉契数列,我们需要弄懂斐波拉契数列元素之间的关系。及后一个元素为前两个元素之和,数列前两个数等于1.由于题目要求n《=39.则开了一个40的数组(第零位不用)。通过while循环,计算第n位斐波拉契数列的值。
思路优化:
前面的思路需要维护一个数组,但在计算后续数值时只需要前面两个数即可,因此不需要维护一个数组,而只需维护前两个数的值(可用赋值运算维护即可)
代码
public class Solution {
    public int Fibonacci(int n) {
        int[] a=new int[40];
        a[1]=1;
        a[2]=1;
        int i=3; 
         while(i<=n){
             a[i]=a[i-1]+a[i-2];
             i++;
         }
        return a[n];
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值