求斐波那契数列的5种实现--JavaEE23,xuef

斐波那契数列 1,1,2,3,5,8,13,21....
通项公式 fib(n) = fib(n-1) + fib(n-2)
1. 普通迭代
...
2. 普通递归

[Java] 纯文本查看 复制代码

?

1

2

3

private static long fib(int n){

    return n<=2?1:(fib(n-1)+fib(n-2));

}



3. 带缓存的递归
        

[Java] 纯文本查看 复制代码

?

1

2

3

4

5

6

7

8

9

static Map<Integer,Long> cache2 = new HashMap<>();

        private static long fib2(int n){

        if(n <= 2) return 1L;

        if(cache2.containsKey(n))

            return cache2.get(n);

        Long fibn = fib2(n-1)+fib2(n-2);

        cache2.put(n, fibn);

        return fibn;

    }



4. 使用 BigInteger 防止溢出

[Java] 纯文本查看 复制代码

?

01

02

03

04

05

06

07

08

09

10

11

12

13

14

15

16

17

static Map<Integer, BigInteger> cache = new HashMap<>();

    public static void main(String[] args) {

        int n = 100;

        BigInteger bi = fib(n);

        System.out.println(bi);

    }

 

    private static BigInteger fib(int n) {

        if(n <= 2) return BigInteger.ONE;

        if(cache.containsKey(n))

            return cache.get(n);

         

        BigInteger t = new BigInteger(fib(n-1).toByteArray()).

                add(new BigInteger(fib(n-2).toByteArray()));

        cache.put(n, t);

        return t;

    }


5. 斐波那契数列迭代器

[Java] 纯文本查看 复制代码

?

01

02

03

04

05

06

07

08

09

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

/**

 * 定义一个遍历器,用于遍历斐波那契数字。

 *

 * @author moveb

 *

 */

public class T24_13_FibonacciIterator implements Iterator<Integer> {

    private int upBound = 23302;

    private int pre = 1;

    private int cur = 1;

     

    public T24_13_FibonacciIterator(){}

     

    public T24_13_FibonacciIterator(int ub){

        upBound = ub;

    }

     

    @Override

    public boolean hasNext() {

        return (cur < upBound);

    }

 

    @Override

    public Integer next() {

        int fib = cur;

        cur = cur + pre;

        pre = fib;

        return fib;

    }

 

    @Override

    public void remove() {

         

    }

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值