Design Min Stack - Amazon Interview Question - Leetcode 155 - Python

Поделиться
HTML-код
  • Опубликовано: 7 янв 2025

Комментарии • 154

  • @TechDevNick
    @TechDevNick 2 года назад +110

    It's so amazing how simple a problem looks when you get to understand the tricky part

  • @ThePacemaker45
    @ThePacemaker45 Год назад +78

    I love how the name of the problem itself is actually the biggest hint.

    • @ladydimitrescu1155
      @ladydimitrescu1155 10 месяцев назад +1

      omg just noticed that

    • @stylisgames
      @stylisgames 7 месяцев назад +3

      Only those who have already solved the problem will get it IMO the actual hint on Leetcode is much better

  • @josephjoestar4318
    @josephjoestar4318 Год назад +17

    Friends, If you use a Linked List it won't have to reallocate when the array reaches it's limit and you can push the min value into the nodes, so head node always have the min.
    Love your work NeetCode. Even if I nail the answer, I always check your solution and I learn something, even if it's just syntax tricks.

    • @namelesss8226
      @namelesss8226 4 месяца назад +1

      What do you mean, could you explain a bit more?

    • @josephjoestar4318
      @josephjoestar4318 4 месяца назад +2

      @@namelesss8226 Sorry I don't have the brain power to go through this video currently. But based on past me's comment, arrays are stored in memory as one block, when you add to it, behind the scenes, it creates a new array with the new length and copies over the values. Some languages when creating arrays, block out extra space in the case it expands. Linked lists don't have this issue since they aren't stored as one block in memory.

  • @niksintelli
    @niksintelli 3 года назад +63

    Hi NeetCode, I know this is kind of a simple problem but I started recently watching your videos and I did this problem on my own just by seeing your explanation! Thank you so much, keep up the good work

    • @NeetCode
      @NeetCode  3 года назад +9

      That's awesome! Appreciate the kind words!

    • @Vaibhav-h5p
      @Vaibhav-h5p 2 года назад +2

      Same for me! It's so fun watching these videos. And being able to solve the problems without looking at the code is such a good feeling.

    • @cp65143
      @cp65143 Год назад

      X. X

  • @dollyvishwakarma2
    @dollyvishwakarma2 2 года назад +29

    Nice explanation.
    How I solved it was modifying the structure of the stack itself, i.e an element of the stack can be a pair of val and min so far:
    class MinStack:
    def __init__(self):
    self.stack = []
    def push(self, val: int) -> None:
    self.stack.append((val, min(val, self.stack[-1][1] if self.stack else val)))
    def pop(self) -> None:
    self.stack.pop()
    def top(self) -> int:
    return self.stack[-1][0]
    def getMin(self) -> int:
    return self.stack[-1][1]
    # Your MinStack object will be instantiated and called as such:
    # obj = MinStack()
    # obj.push(val)
    # obj.pop()
    # param_3 = obj.top()
    # param_4 = obj.getMin()

    • @hamoodhabibi7026
      @hamoodhabibi7026 2 года назад +1

      Nice! I did it using tuples instead but same it's the same code structure

    • @kofinartey6348
      @kofinartey6348 2 года назад +3

      I did it using a hash map / dictionary for each element of the stack containing both values for the min and the current value. I think this is also a good alternative

    • @jorgealbertorun
      @jorgealbertorun 9 месяцев назад

      I did it this way too! Seemed more intuitive

    • @KermitDominicano
      @KermitDominicano 4 месяца назад

      I did it like this too

  • @sevenscapes
    @sevenscapes 10 месяцев назад +2

    Your way of looking at the problem, effectively simplifies the problem statement. Love your approach!💯

  • @aldolunabueno2634
    @aldolunabueno2634 Год назад +4

    I'm glad I resisted the urge to see the solution, because I really enjoyed getting to the solution from the hint alone. Thanks!

  • @licokr
    @licokr 9 месяцев назад +1

    Thanks for the video. I don't know why but I thought I had to store them as indexes and you know, as it pushes and pops, the index can be different. While watching your videos, I've got to able to stay away from fixed ideas I've had. Surely, solving coding problems is way beyond just coding, memorizing and knowing algorithm or datastructure. thanks a lot Neetcode!

  • @krishnaharshith9854
    @krishnaharshith9854 3 года назад +5

    Just made a small mistake and I realized it after watching your video sir, Excellent explanation, thank you sir🙏

  • @stylisgames
    @stylisgames 7 месяцев назад +1

    See I was solving this problem on the actual neetcode website which does not have the hint about each node in the stack having a minimum value. That hint was all I needed, I actually solved it on my own with that! Would be great if the site included any hints that are on Leetcode.

  • @venkatasundararaman
    @venkatasundararaman 2 года назад +57

    I feel we can have a single stack containing a tuple
    class MinStack:
    def __init__(self):
    self.minStack = []
    def push(self, val: int) -> None:
    minVal = min(val, self.minStack[-1][1] if self.minStack else val)
    self.minStack.append((val, minVal))
    def pop(self) -> None:
    self.minStack.pop()
    def top(self) -> int:
    return self.minStack[-1][0] if self.minStack else None
    def getMin(self) -> int:
    return self.minStack[-1][1] if self.minStack else None

    • @khappekhappe133
      @khappekhappe133 2 года назад

      new to python; how would you write this without the list comprehension way?

    • @expansivegymnast1020
      @expansivegymnast1020 2 года назад

      This is actually a pretty decent way of doing it.

    • @floydian25
      @floydian25 2 года назад

      nice solution

    • @ridhawritescode
      @ridhawritescode 2 года назад

      @@khappekhappe133 There are no list comprehensions here. You may be thinking of how he used pythons "lambdas." When he says "self.minStack[-1][1] if self.minStack else val" for example. That essentially means if the minStack exists, use that value, otherwise use val. In many other languages it would look more like this "self.minStack ? self.minStack[-1][1] : val." He does the same thing on top and getMin, he doesn't need to since these functions will never be called on an empty stack, but just in case I guess. Hope that helps.

    • @akm1237
      @akm1237 Год назад +1

      its the same memory

  • @KermitDominicano
    @KermitDominicano 4 месяца назад +1

    The hint made this so much easier. Instant realization lol

  • @anonimettalontana4944
    @anonimettalontana4944 2 года назад

    Interesting and a lot simpler than my implementation!
    What I did was to keep an array for getting the most recent element and a double linked list for getting the minimum, which is stored right after the dummy head.

  • @syafzal273
    @syafzal273 Год назад

    Your implementation is super clean, I tried adding tuples to a list with the current and current min values but having 2 stacks is so much cleaner IMO

  • @hamza-chaudhry
    @hamza-chaudhry 4 месяца назад

    7:36 That's why I used an ArrayList (in Java) so had to write all the functions manually
    7:50 8:06 How do you know that?
    8:12 Yeah I was confused but don't use Python anyway

  • @a.jayasaivinay
    @a.jayasaivinay 29 дней назад

    I mean we can just directly store a pair in stack like [val, cur_min], , class MinStack:
    def __init__(self):
    self.stack = []
    def push(self, val):
    min_val = float('inf')
    if self.stack:
    min_val = self.stack[-1][1]
    self.stack.append([val, min(val, min_val)])
    def pop(self):
    self.stack.pop()
    def top(self):
    return self.stack[-1][0]
    def getMin(self):
    return self.stack[-1][1]

  • @gnes04
    @gnes04 10 месяцев назад +3

    Leetcode updated this from an easy to medium level lol

  • @deepak655655
    @deepak655655 Год назад +1

    instead of two stack , we can have a single stack with , list of 2 values instead of integer. At index 0 we can store the value and at index 1 we can store minimum till that point.

    • @prajjwaldubey5787
      @prajjwaldubey5787 Год назад +1

      Yes we can do this too. good observation.
      I have implemented it take a look:-
      class MinStack:
      def __init__(self):
      self.stack=[]
      def push(self, val: int) -> None:
      if not self.stack:
      self.stack.append([val,val])
      else:
      if self.stack[-1][1] > val:
      self.stack.append([val,val])
      else:
      self.stack.append([val,self.stack[-1][1]])
      return self.stack
      def pop(self) -> None:
      return self.stack.pop()
      def top(self) -> int:
      return self.stack[-1][0]
      def getMin(self) -> int:
      return self.stack[-1][1]

  • @CST1992
    @CST1992 8 месяцев назад

    Instead of using two stacks, you can also use a single stack which contains tuples of the current and minimum values as explained in the video.
    I've tried it and it works the same way.

  • @shreyaschaudhary-r6d
    @shreyaschaudhary-r6d 5 месяцев назад

    I could never think of such an approach. Thank you!

  • @devenlad
    @devenlad 11 месяцев назад

    Thanks for pointing out hint. As soon as I saw hint, problem was solved in my head.

  • @ninjaturtle205
    @ninjaturtle205 2 года назад +10

    This is how I did. Slightly different than neetcode. The minimums stack is only updated when the most minimum is pushed onto the minStack.
    class MinStack:

    def __init__(self):

    self.stack = []
    self.minimums = []

    def push(self, a):
    self.stack.append(a)
    if len(self.minimums)==0:
    self.minimums.append(a)
    elif a int:
    return self.minimums[-1]
    def top(self) -> int:
    return self.stack[-1]

    • @danny65769
      @danny65769 2 года назад +2

      I did something similar, but storing the indices in the minimums stack. In your solution, a new value should still be stored if it equals to (not only less than) self.minimums[-1], otherwise it won't work if there are duplicate minimums.
      This approach is similar to using a monotonic decreasing stack, except that we don't need to pop smaller values when adding a new value - we just don't add the value to the minimums stack at all if the new value is greater than minimums[-1].

    • @someone3706
      @someone3706 Год назад

      @@danny65769 I did the same way as you said, I forget the equal sign first but I got there eventually. And this was 2x faster than the video solution. Is it because we didn't append the min everytime when it is the same min?

    • @sondolkin
      @sondolkin 7 месяцев назад

      This is the solution I had as well. Was checking the comments to see if others arrived at the same solution. Nice.

  • @swarupsaha9064
    @swarupsaha9064 6 месяцев назад

    If every guy working in FAANG is as much talented as he is, we are so F**** up. Thanks NeetCode For your knowledge. Love from India

  • @jasonswift7468
    @jasonswift7468 2 года назад

    In java. for pop() method. We should notice the below.
    == to determine whether the object is the same (memory address), and equals to determine whether two objects are the same.
    String a = new String("abc");
    String b = new String("abc");
    String c = a;
    System.out.println(a == b); // false
    System.out.println(a == c); // true
    System.out.println(a.equals(b)); // true
    System.out.println(a.equals(c)); // true

  • @RandomShowerThoughts
    @RandomShowerThoughts 5 месяцев назад

    the hint from leetcode was truly amazing tbh

  • @mangalegends
    @mangalegends 2 года назад +4

    Looks like they upgraded this question to a medium. And your solution is better than mine lol, I used a stack and a heap but 2 stacks is simpler

    • @LeetCodeSimplified
      @LeetCodeSimplified 2 года назад

      I also thought of implementing a heap but since pushing new elements onto the heap wouldn't have been O(1), I knew that they were looking for a different solution haha

  • @sergiofranklin8809
    @sergiofranklin8809 2 года назад +4

    here it's asked to have O(1) in all operations, and we are using array, so in that case push/pop operations' complexity is amortized O(1), which means sometimes it'll take O(n) time. So, solution breaks this requirement isn't it? if not, please someone explain

    • @yskida5
      @yskida5 2 года назад

      Isn't the worst-case for both of these O(1)? Why would it take O(n)

    • @RM-xr8lq
      @RM-xr8lq 2 года назад

      ​@@bensinger5897 inserting into dynamic array is O(n) worst case for whenever the array needs to expand, and copy over its elements to a new block of memory (here the stack is implemented with a list/dynamic array)
      since that doesn't happen often (only when array not big enough), the amortized time complexity is O(1)

    • @bensinger5897
      @bensinger5897 2 года назад

      @@RM-xr8lq Thats right, I deleted my comment

    • @randomystick
      @randomystick Год назад

      @@RM-xr8lq think that's an OS/hardware concern and not an algorithm concern which is what the interviewers are looking for, though I wager mentioning it at the end of the interview would be a plus point

  • @thehomiebearfifa3528
    @thehomiebearfifa3528 8 месяцев назад +1

    I'm confused about the pop function. If we pop from the regular stack, why is that equivalent to popping from the minStack? On the first stack, we're removing the top most element (which could be any number), while we also removing the top most element from the min stack which is which is not necessarily the same element? Let's say we add -1 to the stack, while the least number is currently -3, in that case we don't append -1 to the top of the minStack, but we do add it to the regular stack. When we go to pop, we pop both elements (-3 from the minStack, and -1 from the regular stack)?

    • @hoixthegreat8359
      @hoixthegreat8359 5 месяцев назад +1

      The minStack contains the minimum element at that time-every time we add something to the stack, we add the minimum element (incl. the new addition) to the minStack, so they are always the same length.
      It might click in your head a lot better if you work through the code with an example array input. E.g. look at your example (say arr = [1, 10, -3, -1])
      push 1: stack = [1], minStack = [1]
      push 2: stack = [1, 10], minStack = [1, 1]
      push 3: stack = [1, 10, -3], minStack = [1, 1, -3]
      push 4: stack = [1, 10, -3, -1], minStack = [1, 1, -3, -3]

  • @RM-xr8lq
    @RM-xr8lq 2 года назад +3

    this strategy is called 'augmented data structure'

  • @visuality2541
    @visuality2541 2 года назад

    really nice, particularly how the minStack works here.

  • @ahmedanwer6899
    @ahmedanwer6899 2 года назад

    interesting how we cover for the case where the minValue is duplicated in the stack. but leetcode doesnt test that and so if you use just a single variable to hold the min value and like not even update it when the minvalue is poppped, the tests still pass. it also doesn't test duplicate mmin values at all. idek if im making sense. however, the above solution yields slower runtime in leetcode

  • @СергейВоробьёв-ы5л8б

    I am more on java and c++ but am I right that technically [] in python is a structure that will grow with specific coef, creating new array and refill it by existing items every time it goes to limit and newer become smaller?

  • @mokshcodes
    @mokshcodes 5 месяцев назад +1

    Why do you need a stack to keep track of the minimum, can't you just set a min variable m to min(m, currVal)

  • @mohitpatil6689
    @mohitpatil6689 Год назад +1

    I guess there is some Problem in the code while submitting if Minstack() is called on the first call then we couldn't return anything and the test case fail, IDK you have tackle this problme or not but I have got this problem.
    :)

  • @koushika4855
    @koushika4855 4 месяца назад

    Is there any way we can support all the operations by using O(1) space and time?
    Thanks!

  • @inarizakiFan
    @inarizakiFan Год назад

    OMG, I did get the idea to store the min values as well, but for some reason, I created two extra stacks. One for storing the current minimum one for storing the last minimum, and, if I'd just taken a step back, I'd have realized how utterly un-needed that was. That's the kind of shit your brain will come up with when you're tired.

  • @pabloj1336
    @pabloj1336 Год назад +1

    Any other examples of your syntax from line 10?

  • @AlexanderLopez-yx4ck
    @AlexanderLopez-yx4ck Год назад

    wow im over here thinking i had to make a stack class from scratch with a node class and everything lmao

  • @chayex1814
    @chayex1814 2 месяца назад

    Why not implement a normal stack class and use the min() function in getMin(self) like this: "class MinStack:
    def __init__(self):
    self.stack = []
    def push(self, val: int) -> None:
    self.stack.append(val)
    def pop(self) -> None:
    self.stack.pop()
    def top(self) -> int:
    return self.stack[-1]
    def getMin(self) -> int:
    return min(self.stack)"?

  • @OwenWu-f9t
    @OwenWu-f9t Год назад

    why can't we do return self.stack.pop() instead of return self.stack[-1]?

  • @dhruvsolanki4473
    @dhruvsolanki4473 2 месяца назад +1

    Currently it is rated as Medium.

  • @symbol767
    @symbol767 2 года назад +30

    This is marked as "easy" jeez, that O(1) Time complexity makes it medium at least

    • @At-oc3lq
      @At-oc3lq 2 года назад

      right!?!? It took me a minute to realize what I had to do for constant time.

    • @minciNashu
      @minciNashu 2 года назад +6

      it was changed to a medium

    • @Good_Guy_Lex
      @Good_Guy_Lex Год назад

      Took me more that a min. I used a array list instead of a stack for the minStack

    • @TheseOfWe0112
      @TheseOfWe0112 Год назад +1

      It’s a Medium now. But it’s bizarre that this was Easy while #50 Pow(x,n) is (still) listed as Medium! For Py/Java/JS, #50 is the easiest I’ve seen.

    • @EE12345
      @EE12345 11 месяцев назад +1

      its medium now. first time seeing them raise the difficulty tag on a problem, I thought the problems only get harder over time so mediums become easys

  • @zehbarrayani7215
    @zehbarrayani7215 2 года назад

    Seriously the best

  • @bashaarshah2974
    @bashaarshah2974 Год назад

    Doesn't utilizing the min function on line 10 make the run time for that method O(n)?

  • @sunshineandrainbow5453
    @sunshineandrainbow5453 9 месяцев назад

    Please tell how to do it with O(1) space complexity.

  • @kofinartey6348
    @kofinartey6348 2 года назад

    Hi Neetcode … great video 😊😊.. but I’m thinking of an edge case here. What will happen if the getMin() or top() functions are called on an empty stack. From your implementation I think it would throw an error which would be “list index out of range”. So would it be better to put a check with the return statement of those functions to prevent those errors?

    • @NeetCode
      @NeetCode  2 года назад +2

      Yeah good point, in this case I think we're guaranteed no invalid calls will be made, but in a real interview your point would be good to ask.

  • @anshukkl3300
    @anshukkl3300 2 года назад +1

    why can't you use self.q=deque() method here? Do we necessarily need two stacks initialization ?
    ```
    class MinStack(object):
    def __init__(self):
    self.q=deque()
    def push(self, val):
    """
    :type val: int
    :rtype: None
    """
    self.q.append(val)
    def pop(self):
    """
    :rtype: None
    """
    for i in range(len(self.q)-1):
    self.push(self.q.popleft())
    return self.q.popleft()
    def top(self):
    """
    :rtype: int
    """
    return self.q[-1]
    def getMin(self):
    """
    :rtype: int
    """
    min=self.q[-1]
    for i in range(len(self.q)):
    if self.q[i]

  • @Akhil-yy3ip
    @Akhil-yy3ip 2 года назад +2

    class MinStack:
    def __init__(self):
    self.arr = []
    def push(self, val: int) -> None:
    self.arr.append(val)
    def pop(self) -> None:
    self.arr.pop()
    def top(self) -> int:
    return self.arr[-1]
    def getMin(self) -> int:
    return min(self.arr)

    • @hugenerretho9151
      @hugenerretho9151 2 года назад +2

      its o(n) time complexity for min function so doesnt work

  • @misteryue2739
    @misteryue2739 2 года назад

    I don't really get the pop() function, doesn't it need a condition check before pop()ing out off the minStack ?

    • @Senzatie160
      @Senzatie160 2 года назад +1

      Nope, why? Every time you pop an element off the stack, you also pop the min at that level from the minStack.

    • @misteryue2739
      @misteryue2739 2 года назад

      @@Senzatie160 Right, I didn't catch the fact the minStack represented the current minimum so I got confused. So much info when trying to learn algos, I was overwhelmed haha

    • @demdimi9316
      @demdimi9316 Год назад

      @@Senzatie160 thnx lol

  • @noufbouf
    @noufbouf 2 года назад

    I feel like my code is ridiculously simple and it passed the leetcode test. I am doing something wrong?
    class MinStack:
    def __init__(self):
    self.l = []
    def push(self, val: int) -> None:
    self.l.append(val)
    def pop(self) -> None:
    del self.l[-1]
    def top(self) -> int:
    return self.l[-1]
    def getMin(self) -> int:
    return min(self.l)

    • @abeizify
      @abeizify 2 года назад +7

      getMin is O(n) in worst case, but the code from the video is O(1)

  • @florin-alexandrustanciu5643
    @florin-alexandrustanciu5643 Год назад +1

    Wouldn t it be better with a new Node class that has a value and a min? This way you dont store twice the number of pointers

    • @inarizakiFan
      @inarizakiFan Год назад

      But you do store them in the node class right? (for each node you have two variables to store the element and min)? Why would it be better?

  • @Shivam-yy8qe
    @Shivam-yy8qe 2 года назад +1

    thanks nice exaplinations. we can also do this using only one stack using pairs . In first we keep actual value,and in second we store the minimum till that element

  • @Rohit-qp1ye
    @Rohit-qp1ye 3 года назад +1

    Add this to stack playlist

  • @DeveloperCoder
    @DeveloperCoder Год назад

    MinStack Java Solution:
    ruclips.net/video/lHynQtJUcXs/видео.html

  • @itdepends5906
    @itdepends5906 2 года назад

    Awesome clear video :)

  • @shawnlu7830
    @shawnlu7830 2 года назад

    how about we just use the built in min() function in python to get the min value, this way we dont need another stack, so it saves some space

    • @spaghettiking653
      @spaghettiking653 Год назад

      This is true, but min() goes over the whole stack in order to calculate the min, so this takes O(n) and it needs to be O(1) for the solution to be accepted.

  • @ruiqiyin3847
    @ruiqiyin3847 2 года назад

    You made it so easy!
    Could you do Max Stack too?

  • @weaammohamed8992
    @weaammohamed8992 2 года назад

    Great explanation!

  • @TheseOfWe0112
    @TheseOfWe0112 Год назад

    I looked at this problem yesterday and it was listed as Medium.

  • @jinwoopark755
    @jinwoopark755 3 года назад

    Can you do accounts merge explanation please?

  • @xedose7183
    @xedose7183 9 месяцев назад

    Nice Explanation

  • @mrditkovich2339
    @mrditkovich2339 3 года назад +5

    Without extra space, the intuition is like :
    When we are popping a value from stack,
    if it is the minimum, then we need to know the minimum of remaining numbers. Can we try to adjust this in the same stack instead of a separate min stack ?
    yes, we can ensure this by pushing an extra value
    While pushing, we will check if the element we are pushing is less than minimum, in this case, we have to push the existing min number and then the new number. After this, our new number becomes the updated minimum.
    Now while popping,
    If we are popping the number and it is min, we pop an extra value out of the stack, this extra becomes the updated minimum.

    • @minciNashu
      @minciNashu 2 года назад

      you actually do it by pushing differences, instead of actual values, for new minimums

    • @nos44-
      @nos44- 2 года назад

      How is that any different form taking two stacks .. you are occupying the same. Space !! Isn't it... You are increasing the size of this array ... Instead of taking a separate one ... 😶

  • @mr_noob6361
    @mr_noob6361 Год назад

    Your logic building is fabulous..how u r doing this Mann😑😑😑 thats the reason u r in Google and i am still unemployed...sir it's my humble req please provide python and DSA tutorials for free😔😔👏👏

  • @bestsaurabh
    @bestsaurabh 3 года назад +1

    If this is tricky, I am just wondering how tricky it is to do this without using any extra space??! I

    • @minciNashu
      @minciNashu 2 года назад

      store differences

    • @tivialvarez
      @tivialvarez Год назад

      probably have moved on but I just found a video with a pretty clever solution ruclips.net/video/V09NfaGf2ao/видео.html

  • @martinemanuel8239
    @martinemanuel8239 2 года назад

    I'ts a perfect exercise to implement your own stack to :P

  • @mnchester
    @mnchester 2 года назад +2

    This is a Medium now

  • @souljarohill8795
    @souljarohill8795 3 месяца назад

    leetcode is so weird. some mediums like this one are way easier than some easy problems lol

  • @iIrfanhussain
    @iIrfanhussain Год назад

    We can do this qn by O(N) space but it's super hard

    • @inarizakiFan
      @inarizakiFan Год назад

      for O(n) you'd traverse the elements, which wouldn't really work if the data structure is a proper stack since you can only access the top value. You could do it in a clumsy way by popping from a copy stack to traverse though.

  • @T2000-f3j
    @T2000-f3j 19 дней назад

    yooo that one stack solution

  • @asdfasyakitori8514
    @asdfasyakitori8514 Год назад

    This is so clever

  • @hambroman
    @hambroman 10 месяцев назад +1

    the thumbnail for this is a spoiler lol

  • @e555t66
    @e555t66 3 года назад +6

    Neat.

  • @ssuriset
    @ssuriset 7 месяцев назад

    "Consider each node in the stack having a minimum value." How is a normal person supposed to understand this?

  • @aabhishek4911
    @aabhishek4911 2 года назад

    does python not have an inbuilt stack ? feel like you using an array for these stack problems kind of weird.

    • @minciNashu
      @minciNashu 2 года назад

      thats technically a list, but even so, for example the C++ vector can do push and pop

    • @SuubUWU
      @SuubUWU Год назад

      Technically the problem is asking you to "design" a min stack. In real-life coding interviews, it honestly depends on the interviewer.
      Some will let it slide because they don't expect you to write your own min stack structure.
      Others will see it as a potential crutch because you couldn't demonstrate that you could design it.
      It's good to know built-in language libraries to save time when they're allowed but only if you understand how to design them from scratch once you're 3~6 interviews in. They have to start finding reasons to disqualify you from other candidates.
      The best practice here is to simply ask if you can use a standard library.

  • @wybsl5087
    @wybsl5087 Год назад

    This question is medium now 🧐

  • @dhelmy
    @dhelmy 2 месяца назад

    Doomed enterprises divide lives forever into the then and the now.

  • @CEOofTheHood
    @CEOofTheHood 3 года назад +9

    i feel like this is a terrible interview question. You just need to know the trick and question solves itself

    • @abhishekshah4443
      @abhishekshah4443 3 года назад +10

      Pretty much all the coding interview rounds and their questions are like that (which is still a terrible thing)

    • @mikaylatheengineer9631
      @mikaylatheengineer9631 3 года назад +3

      isn't that all tech interview questions?

    • @CEOofTheHood
      @CEOofTheHood 3 года назад

      @@mikaylatheengineer9631 no some require mental application

    • @motivewave001
      @motivewave001 3 года назад +1

      @@CEOofTheHood only when you don’t know the tricks

    • @austinchettiar6784
      @austinchettiar6784 3 года назад

      @@motivewave001 what is the space complexity? is it 2n? can anyone tell

  • @sanooosai
    @sanooosai Год назад

    thnak you sir

  • @TOn-fx2gr
    @TOn-fx2gr Год назад

    You have a bug in the pop method of your minstack class

  • @swaroopkv4540
    @swaroopkv4540 2 года назад

    Y pop from both stack

  • @yy-ll1uw
    @yy-ll1uw Год назад

    So elegant

  • @vikasgupta1828
    @vikasgupta1828 Год назад

    Thanks

  • @jewsefjones
    @jewsefjones 4 месяца назад

    Pop returning none irks me

  • @programming3043
    @programming3043 2 года назад

    Done

  • @tsunningwah3471
    @tsunningwah3471 Год назад

    斤斤計較

  • @АльбусДамблодр
    @АльбусДамблодр Год назад

    i love u

  • @jonaskhanwald566
    @jonaskhanwald566 3 года назад

    576. Out of Boundary Paths. Do a video on this