FibonacciNumber::fib3()   A
last analyzed

Complexity

Conditions 3
Paths 3

Size

Total Lines 13
Code Lines 8

Duplication

Lines 0
Ratio 0 %

Importance

Changes 2
Bugs 0 Features 0
Metric Value
eloc 8
c 2
b 0
f 0
dl 0
loc 13
rs 10
cc 3
nc 3
nop 1
1
<?php
2
3
declare(strict_types=1);
4
5
namespace leetcode;
6
7
class FibonacciNumber
8
{
9
    public static function fib(int $n): int
10
    {
11
        if ($n <= 1) {
12
            return $n;
13
        }
14
15
        return self::fib($n - 1) + self::fib($n - 2);
16
    }
17
18
    public static function fib2(int $n): int
19
    {
20
        if ($n < 2) {
21
            return $n;
22
        }
23
        $dp = array_fill(0, $n + 1, 0);
24
        $dp[0] = 0;
25
        $dp[1] = 1;
26
        for ($i = 2; $i < $n + 1; $i++) {
27
            $dp[$i] = $dp[$i - 1] + $dp[$i - 2];
28
        }
29
30
        return $dp[$n];
31
    }
32
33
    public static function fib3(int $n): int
34
    {
35
        if ($n < 2) {
36
            return $n;
37
        }
38
        [$a, $b, $c] = [0, 1, 0];
39
        for ($i = 1; $i < $n; $i++) {
40
            $c = $a + $b;
41
            $a = $b;
42
            $b = $c;
43
        }
44
45
        return $c;
46
    }
47
}
48