-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy path28_November.java
40 lines (36 loc) · 1019 Bytes
/
28_November.java
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
class Solution {
ArrayList<Integer> findSubarray(int a[], int n) {
// code here
int maxSum=0;
int maxStart=0;
int maxEnd=0;
int currSum=0;
int currStart=0;
for(int i=0;i<n;i++){
if(a[i]<0){
currSum=0;
currStart=i+1;
}else{
currSum+=a[i];
}
if(currSum>maxSum){
maxSum=currSum;
maxStart=currStart;
maxEnd=i+1;
}else if(currSum==maxSum){
int currDis=i+1-currStart;
int maxDis=maxEnd-maxStart;
if(currDis>maxDis){
maxStart=currStart;
maxEnd=i+1;
}
}
}
ArrayList<Integer> ans=new ArrayList<>();
for(int i=maxStart;i<maxEnd;i++){
ans.add(a[i]);
}
if(ans.size()==0)ans.add(-1);
return ans;
}
}