forked from spandey1296/Learn-Share-Hacktoberfest2021
-
Notifications
You must be signed in to change notification settings - Fork 5
/
SlidingWindowMaximum.java
76 lines (59 loc) · 2.41 KB
/
SlidingWindowMaximum.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
package oops;
//---------------------------QUESTION--------------------------------------
//You are given an array of integers nums, there is a sliding window of size k
//which is moving from the very left of the array to the very right
//. You can only see the k numbers in the window.
//Each time the sliding window moves right by one position.
//Return the max sliding window.
//-----------------------------QUESTION LINK ON LEETCODE-----------------------
// https://leetcode.com/problems/sliding-window-maximum/description/
//---------------------------Solution-----------------------
import java.util.Deque;
import java.util.LinkedList;
public class SlidingWindowMaximum {
// A Dequeue (Double ended queue) based method for printing maximum element of
// all subarrays of size k
static void printMax(int arr[], int n, int k)
{
// Create a Double Ended Queue, Qi that will store indexes of array elements
// The queue will store indexes of useful elements in every window and it will
// maintain decreasing order of values from front to rear in Qi, i.e.,
// arr[Qi.front[]] to arr[Qi.rear()] are sorted in decreasing order
Deque<Integer> Qi = new LinkedList<>();
/* Process first k (or first window) elements of array */
int i;
for (i = 0; i < k; ++i) {
// For every element, the previous smaller elements are useless so
// remove them from Qi
while (!Qi.isEmpty() && arr[i] >= arr[Qi.peekLast()])
Qi.removeLast(); // Remove from rear
// Add new element at rear of queue
Qi.addLast(i);
}
// Process rest of the elements, i.e., from arr[k] to arr[n-1]
for (; i < n; ++i) {
// The element at the front of the queue is the largest element of
// previous window, so print it
System.out.print(arr[Qi.peek()] + " ");
// Remove the elements which are out of this window
while (!Qi.isEmpty() && Qi.peek() <= i - k)
Qi.removeFirst();
// Remove all elements smaller than the currently
// being added element (remove useless elements)
while (!Qi.isEmpty() && arr[i] >= arr[Qi.peekLast()])
Qi.removeLast();
// Add current element at the rear of Qi
Qi.addLast(i);
}
// Print the maximum element of last window
System.out.print(arr[Qi.peek()]);
}
// Driver program to test above functions
public static void main(String[] args)
{
int arr[] = { 4,7,6,2,4,8,7};
int k = 3;
printMax(arr, arr.length, k);
}
}
// This code is contributed by Sumit Ghosh