Find in Mountain Array - Leetcode 1095 - Python

  Рет қаралды 11,719

NeetCodeIO

NeetCodeIO

Күн бұрын

Пікірлер
@pranav2066
@pranav2066 Жыл бұрын
This has become my routine. Leetcode all day and daily challenge with Neetcode at Night! Thanks for the Videos
@steeve1
@steeve1 Жыл бұрын
I think most hards are pretty silly but I liked this one, probably because i'm comfortable with binary search and didn't feel there was some obscure trick that i'm supposed to magically know.
@angelchen2843
@angelchen2843 10 ай бұрын
Quite easy to understandable!!!! ❤❤
@rudrakhare1158
@rudrakhare1158 5 ай бұрын
Corrected Code :_ class Solution: def findInMountainArray(self, target: int, mountain_arr: 'MountainArray') -> int: length = mountain_arr.length() # Find the peak of the mountain array l, r = 0, length - 1 while l < r: m = (l + r) // 2 if mountain_arr.get(m) < mountain_arr.get(m + 1): l = m + 1 else: r = m peak = l # Binary search on the increasing part l, r = 0, peak while l target: r = m - 1 else: return m # Binary search on the decreasing part l, r = peak, length - 1 while l target: l = m + 1 # This should be r = m - 1 elif val < target: r = m - 1 # This should be l = m + 1 else: return m return -1
@GuruPrasadShukla
@GuruPrasadShukla Жыл бұрын
keep solving mate!
@picnicbros
@picnicbros Жыл бұрын
I love binary search
@silent7152
@silent7152 Жыл бұрын
Bro help me out 1. Use while(l
@picnicbros
@picnicbros Жыл бұрын
@@silent7152 I suggest you read "Powerful Ultimate Binary Search Template" (search on google) to never have bug in your binary search again! The template is basically: left, right = min(search_space), max(search_space) while left < right: mid = left + (right - left) // 2 if condition(mid): left = mid + 1 else: right = mid return left where the else here include the exiting condition *as well as* condition when you update the right pointer. If you do that, in the else statement you can safely update the right pointer. Essentially, you *dont* want to have the exiting condition when you update the left pointer! The template also can be rewritten with those points in mind and still work: left, right = min(search_space), max(search_space) while left < right: mid = left + (right - left) // 2 if condition(mid) or exiting_condition(mid): right = mid else: left = mid + 1 return left So, for this problem, here is two method that will return the peak index: Update left pointer in if condition() method: easier since you don't have to find the exiting condition: while l < r: m = l + (r - l) // 2 if mountain_arr.get(m - 1) < mountain_arr.get(m) < mountain_arr.get(m + 1): l = m + 1 else: r = m peak = l Update right pointer in if condition or exiting_condition() method: while l < r: m = l + (r - l) // 2 left, mid, right = mountain_arr.get(m - 1), mountain_arr.get(m), mountain_arr.get(m + 1) if left > mid > right or (mid > left and mid > right) : r = m else: l = m + 1 peak = l Some side note: this template assumes that the item you want to search is in the range you define. If it is not, it will return the next index that it "assume" the item will be. For example: [1 2 3 4 5], if you search 12, it will assume that 12 will be at index 5, which does not exist in the search space, but it is correct given the condition that arr[i] < arr[i + 1] (sorted array) Also, this template return the first occurrence of your target,if your target has duplicate. For example: [1 2 3 3 3 6 7] if you search 3, it will return 2 (the first occurrence) If you want to find the last occurrence, simply search for target + 1 instead. It will then "assume" the item target + 1 will be in the next position of the last occurrence of target: [1 2 3 3 3 6 7] if you search 4 (target 3 + 1), it will return left = 5. Now, index 5 doesn't have 4, but 6, but that's okay, we simply return left - 1 and that's our last occurrence of target 3. I suggest you do Find First and Last Position of Element in Sorted Array and implement these points. Good luck!
@adrianengcheeern
@adrianengcheeern 11 ай бұрын
Is there a possibility that m - 1 or m + 1 would go out of range of the list?
@rajarshiverma7686
@rajarshiverma7686 Жыл бұрын
Thanks for the great solution, can you also mention how to use bisect here as I have seen solution where few people used bisect
@dera_ng
@dera_ng Жыл бұрын
Do you think I over-thought the question? Maybe if i was in a real interview then I could ask the interviewer if there could be multiple peaks. The English structure of the question promoted me to think about it a bit more and then I got hung up on the edge case (if valid) of having multiple peaks. 😢..... If it's a hard question, I was expecting it to be harder than this.
@yfjsdgzjdnfn
@yfjsdgzjdnfn Жыл бұрын
NeetCode please solve Leetcode 8 String to Integer there are many edge cases out there in that problem ,I requesting please do Video on that
@sumtpathak19
@sumtpathak19 Жыл бұрын
the reason behind using mountainArray class is to calculate no. of .get not exceed 100
@hikumai289
@hikumai289 Жыл бұрын
This is medium rather than hard. Wish all of you a good day.
@user-le6ts6ci7h
@user-le6ts6ci7h Жыл бұрын
You can't do linear search here eventhough the input size is of 10 pow 4 , because you can call the get at max 100 whixh is enforced by the interface, so better way is use binary search and which takes at max
Painting the Walls - Leetcode 2742 - Python
14:29
NeetCodeIO
Рет қаралды 15 М.
I Solved 100 LeetCode Problems
13:11
Green Code
Рет қаралды 288 М.
Quando eu quero Sushi (sem desperdiçar) 🍣
00:26
Los Wagners
Рет қаралды 15 МЛН
Support each other🤝
00:31
ISSEI / いっせい
Рет қаралды 81 МЛН
Гениальное изобретение из обычного стаканчика!
00:31
Лютая физика | Олимпиадная физика
Рет қаралды 4,8 МЛН
When you have a very capricious child 😂😘👍
00:16
Like Asiya
Рет қаралды 18 МЛН
Search in rotated sorted array - Leetcode 33 - Python
13:28
NeetCode
Рет қаралды 373 М.
Making an Algorithm Faster
30:08
NeetCodeIO
Рет қаралды 183 М.
Find K-th Smallest Pair Distance - Leetcode 719 - Python
25:35
NeetCodeIO
Рет қаралды 16 М.
LeetCode was HARD until I Learned these 15 Patterns
13:00
Ashish Pratap Singh
Рет қаралды 684 М.
Clean Code is SLOW But REQUIRED? | Prime Reacts
28:22
ThePrimeTime
Рет қаралды 332 М.
When Optimisations Work, But for the Wrong Reasons
22:19
SimonDev
Рет қаралды 1,1 МЛН
This Algorithm is 1,606,240% FASTER
13:31
ThePrimeagen
Рет қаралды 858 М.
Search in Rotated Sorted Array II - Leetcode 81 - Python
17:36
NeetCodeIO
Рет қаралды 17 М.
Quando eu quero Sushi (sem desperdiçar) 🍣
00:26
Los Wagners
Рет қаралды 15 МЛН