MaximumSubarray   A
last analyzed

Complexity

Total Complexity 10

Size/Duplication

Total Lines 47
Duplicated Lines 0 %

Importance

Changes 2
Bugs 0 Features 0
Metric Value
wmc 10
eloc 25
c 2
b 0
f 0
dl 0
loc 47
rs 10

3 Methods

Rating   Name   Duplication   Size   Complexity  
A maxSubArray3() 0 13 3
A maxSubArray2() 0 13 3
A maxSubArray() 0 15 4
1
<?php
2
3
declare(strict_types=1);
4
5
namespace leetcode;
6
7
class MaximumSubarray
8
{
9
    public static function maxSubArray(array $nums): int
10
    {
11
        if (empty($nums)) {
12
            return 0;
13
        }
14
        [$ans, $n] = [PHP_INT_MIN, count($nums)];
15
        for ($i = 0; $i < $n; $i++) {
16
            $sum = 0;
17
            for ($j = $i; $j < $n; $j++) {
18
                $sum += $nums[$j];
19
                $ans = max($ans, $sum);
20
            }
21
        }
22
23
        return $ans;
24
    }
25
26
    public static function maxSubArray2(array $nums): int
27
    {
28
        if (empty($nums)) {
29
            return 0;
30
        }
31
32
        [$ans, $sum] = [$nums[0], 0];
33
        foreach ($nums as $num) {
34
            $sum = max($sum + $num, $num);
35
            $ans = max($ans, $sum);
36
        }
37
38
        return $ans;
39
    }
40
41
    public static function maxSubArray3(array $nums): int
42
    {
43
        if (empty($nums)) {
44
            return 0;
45
        }
46
        $n = count($nums);
47
        $dp = array_fill(0, $n, 0);
48
        $dp[0] = $nums[0];
49
        for ($i = 1; $i < $n; $i++) {
50
            $dp[$i] = max($dp[$i - 1] + $nums[$i], $nums[$i]);
51
        }
52
53
        return max($dp);
54
    }
55
}
56