Leetcode 852 Peak Index in a Mountain Array
Let's call an array arr a mountain if the following properties hold:
arr.length >= 3
There exists some i with 0 < i < arr.length - 1 such that:
arr[0] < arr[1] < ... arr[i-1] < arr[i]
arr[i] > arr[i+1] > ... > arr[arr.length - 1]
Given an integer array arr that is guaranteed to be a mountain, return any i such that arr[0] < arr[1] < … arr[i - 1] < arr[i] > arr[i + 1] > … > arr[arr.length - 1].
Input: arr = [0,1,0]
Output: 1
Input: arr = [0,2,1,0]
Output: 1
Input: arr = [0,10,5,2]
Output: 1
Input: arr = [3,4,5,1]
Output: 2
- Pythonda tek satırla çözüm aşağıdaki gibidir.En yüksek değerli sayı tepe noktasını oluşturur.
def peakIndexInMountainArray(self, A):
return A.index(max(A))
- Ama bir algoritma ile çözmek istersek Binary Search arama kullanabiliriz.
- Ortadan başlayarak kontrollere başlarız.Eğer bulduğumuz sayı sağ ve solundaki sayılardan büyük ise cevabı bulmuşuzdur.Değil ise hangi taraftaki sayılardan büyük ise o parçayı çıkartır ve arama listesini daraltırız.Örneğin bulduğumuz sayı soldaki sayıdan büyük sağdaki sayıdan küçük ise bu durumda mid+1 yeni low değerimiz olacaktır.
def peakIndexInMountainArray(self, A: List[int]) -> int:
low, high = 0, len(A) - 1
while low <= high:
mid = (low + high) // 2
if A[mid] > A[mid-1] and A[mid] > A[mid+1]:
return mid
if A[mid-1] < A[mid] < A[mid+1]:
low = mid + 1
if A[mid-1] > A[mid] > A[mid+1]:
high = mid - 1