-
Notifications
You must be signed in to change notification settings - Fork 1k
/
Copy pathMaximumSumSubarray.java
77 lines (63 loc) · 1.98 KB
/
MaximumSumSubarray.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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
/**
* Maximum Sum Subarray of Size K
* Java program to find the maximum sum of a subarray of fixed size K,
* given an array of integers, using the 'Sliding Window Technique'.
*/
import java.util.*;
public class MaximumSumSubarray {
public static int maximumSum(int[] numArray, int K) {
int currentSum = 0;
//Calculating sum for first window of size K
for(int i=0; i<K; i++)
currentSum += numArray[i];
//Storing maximum sum till current window
int maxSum = currentSum;
//Finding sum of all possible K-sized windows, one by one
int subtractIndex = 0;
for(int i=K; i<numArray.length; i++) {
currentSum += numArray[i] - numArray[subtractIndex];
subtractIndex++;
maxSum = Math.max(maxSum, currentSum);
}
return maxSum;
}
public static void main(String[] args) {
Scanner scan = new Scanner(System.in);
//Taking input from user
System.out.println("Enter length of array and size of window: ");
int length = scan.nextInt();
int K = scan.nextInt();
int numArray[] = new int[length];
System.out.println("Enter array elements: ");
for(int i=0; i<length; i++) {
numArray[i] = scan.nextInt();
}
if(K > length || K <= 0)
System.out.println("Invalid input");
else {
System.out.println("Maximum sum of a subarray of size " + K + ":");
System.out.println(maximumSum(numArray, K));
}
}
}
/*
Time complexity: O(N)
Space complexity: O(1)
TEST CASES
INPUT
Enter length of array and size of window:
10 3
Enter array elements:
1 7 -2 4 5 2 1 6 11 -4
OUTPUT
Maximum sum of a subarray of size 3:
18
INPUT
Enter length of array and size of window:
8 4
Enter array elements:
2 4 0 1 5 2 9 3
OUTPUT
Maximum sum of a subarray of size 4:
19
*/