| Total Complexity | 10 |
| Total Lines | 47 |
| Duplicated Lines | 0 % |
| Changes | 2 | ||
| Bugs | 0 | Features | 0 |
| 1 | <?php |
||
| 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 |
||
| 54 | } |
||
| 55 | } |
||
| 56 |