Similar Problems
Similar Problems not available
Find A Peak Element Ii - Leetcode Solution
LeetCode: Find A Peak Element Ii Leetcode Solution
Difficulty: Medium
Topics: matrix binary-search array
Problem Statement: A peak element in a two-dimensional array is an element that is greater than or equal to its four neighbors, left, right, top and bottom.
For example, in the picture below, the peak element is 9:
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
Find all peak elements in a given two-dimensional array. Return their indices as a list of lists.
Solution Approach:
To solve this problem, we need to find out all the local maximums or peak elements in the input matrix. For this purpose, we can apply a recursive divide-and-conquer approach by dividing the matrix into smaller sub-matrices at each step and finding the peak element in each sub-matrix. The peak element in a sub-matrix will be the element that is maximum among the elements in the sub-matrix and its neighbors. We can recur on the sub-matrix that contains the peak element until we reach the smallest sub-matrix where we can directly find the peak element. Finally, we can combine all the peak elements obtained from various sub-matrices to get the final answer.
Algorithm:
-
Define a recursive function findPeakElements() that takes the input matrix, row and column indices of the top-left and bottom-right corners of the sub-matrix as input.
-
If the sub-matrix contains only one element, return the index of the element as the peak element.
-
Calculate the middle column index midCol = (startCol + endCol) / 2.
-
Find the maximum element maxElement in the midCol-th column of the sub-matrix.
-
Find the row index maxRow of the maximum element maxElement in the midCol-th column.
-
If maxElement is greater than the elements in both of its adjacent columns, then maxElement is a peak element, return its index (maxRow, midCol).
-
Otherwise, if the element to the left of maxElement is greater than maxElement, then recur on the left half of the sub-matrix (findPeakElements(matrix, startRow, startCol, endRow, midCol-1)).
-
Otherwise, if the element to the right of maxElement is greater than maxElement, then recur on the right half of the sub-matrix (findPeakElements(matrix, startRow, midCol+1, endRow, endCol)).
-
If maxElement is not a peak element and we do not have any unexplored sub-matrix, then return an empty list.
-
Finally, combine all the peak elements obtained from various sub-matrices and return the final list.
Pseudo Code:
def findPeakElements(matrix, startRow, startCol, endRow, endCol):
# Base Case: Sub-matrix contains only one element
if startRow == endRow and startCol == endCol:
return [[startRow, startCol]]
# Calculate the middle column index
midCol = (startCol + endCol) // 2
# Find the maximum element in the midCol-th column of sub-matrix
maxElement = matrix[startRow][midCol]
maxRow = startRow
for i in range(startRow, endRow+1):
if matrix[i][midCol] > maxElement:
maxElement = matrix[i][midCol]
maxRow = i
# If maxElement is a peak element, return its index
if ((midCol == 0 or matrix[maxRow][midCol-1] <= maxElement) and
(midCol == len(matrix[0])-1 or matrix[maxRow][midCol+1] <= maxElement) and
(maxRow == 0 or matrix[maxRow-1][midCol] <= maxElement) and
(maxRow == len(matrix)-1 or matrix[maxRow+1][midCol] <= maxElement)):
return [[maxRow, midCol]]
# Recur on the left half of the sub-matrix
if midCol > 0 and matrix[maxRow][midCol-1] > maxElement:
return findPeakElements(matrix, startRow, startCol, endRow, midCol-1)
# Recur on the right half of the sub-matrix
if midCol < len(matrix[0])-1 and matrix[maxRow][midCol+1] > maxElement:
return findPeakElements(matrix, startRow, midCol+1, endRow, endCol)
# No peak element found in the sub-matrix
return []
def findPeakElements2D(matrix):
return findPeakElements(matrix, 0, 0, len(matrix)-1, len(matrix[0])-1)
Time Complexity: The time complexity of the above recursive divide-and-conquer algorithm is O(N * logM) where N is the total number of elements in the input matrix and logM is the number of times we can halve the matrix size and search for the peak element. The worst-case time complexity occurs when the input matrix is a square matrix where logM is logN (base 2).
Space Complexity: The space complexity of the above recursive divide-and-conquer algorithm is O(logM) where logM is the maximum depth of the recursion tree.
Find A Peak Element Ii Solution Code
1There is no peak element in the given array.
2
3class Solution {
4public:
5 int findPeakElement(vector<int>& nums) {
6 int n = nums.size();
7 int left = 0, right = n - 1;
8 while (left < right) {
9 int mid = left + (right - left) / 2;
10 if (nums[mid] < nums[mid + 1]) {
11 left = mid + 1;
12 } else {
13 right = mid;
14 }
15 }
16 return left;
17 }
18};