-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMaximum_Sum_Contiguous_Subarray.php
More file actions
48 lines (46 loc) · 1.06 KB
/
Maximum_Sum_Contiguous_Subarray.php
File metadata and controls
48 lines (46 loc) · 1.06 KB
1
2
3
4
5
6
7
8
9
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
36
37
38
39
40
41
42
43
44
45
46
47
48
<?php
class Solution
{
function maxSubArray($nums)
{
if ($this->allNegative($nums)) {
return max($nums);
}
if ($this->allPositive($nums)) {
return array_sum($nums);
}
$maxsum = PHP_INT_MIN;
$currentSum = 0;
for ($i = 0; $i < count($nums); $i++) {
if ($nums[$i] > $maxsum) {
$maxsum = $nums[$i];
}
$currentSum += $nums[$i];
if ($currentSum < 0) {
$currentSum = 0;
}
if ($currentSum > $maxsum) {
$maxsum = $currentSum;
}
}
return $maxsum;
}
function allNegative($nums)
{
for ($i = 0; $i < count($nums); $i++) {
if ($nums[$i] > 0) {
return false;
}
}
return true;
}
function allPositive($nums)
{
for ($i = 0; $i < count($nums); $i++) {
if ($nums[$i] < 0) {
return false;
}
}
return true;
}
}