L8. Trapping Rainwater | 2 Approaches | Stack and Queue Playlist

Поділитися
Вставка
  • Опубліковано 23 січ 2025

КОМЕНТАРІ • 142

  • @brokegod5871
    @brokegod5871 6 місяців тому +172

    the prefix/suffix match approach is a lot better to understand imo

    • @nomi98
      @nomi98 4 місяці тому +5

      I think people can't understand this one from any of the available videos because they're glossing over some things, which either they don't understand or they find not worth mention (or simply forget).
      I just wrote down step by step how I would solve it with two pointers and figured out why they were doing what they were doing. I finally understand this shit 😭.

    • @kulyashdahiya2529
      @kulyashdahiya2529 3 місяці тому +2

      it's a DP apprach.

    • @sudipsarkar1512
      @sudipsarkar1512 Місяць тому

      ​@@kulyashdahiya2529 how so, bro ?

  • @b_technical4017
    @b_technical4017 6 місяців тому +35

    Striver you don't know how much this is helping us!! Thank you so so so Much!
    No one can explain DSA better than you❤❤😭

    • @shreyxnsh.14
      @shreyxnsh.14 4 місяці тому +8

      wrong problem to say this, barely anyone understood what he said in the second approach

    • @rwordspecialist6734
      @rwordspecialist6734 2 місяці тому

      Fr😂😂​@@shreyxnsh.14 gotta see once more will see what I'm missing

    • @ajaymishra1511
      @ajaymishra1511 Місяць тому

      @@shreyxnsh.14 well this problem is actually pretty hard to explain you will need to imagine the whats actually happening

  • @hashcodez757
    @hashcodez757 6 місяців тому +80

    CORRECTION->
    22:51 we have to take the smaller one

    • @omkarshendge5438
      @omkarshendge5438 6 місяців тому +2

      yup exactly we will go with the smaller one.

    • @riyaraj5720
      @riyaraj5720 5 місяців тому +2

      yess

    • @nitinxd98
      @nitinxd98 5 місяців тому +7

      i watched this video three times again for the opetimal approach and got confused as soon as he took the 2 instead of 1 thanks for clearing

    • @lillyput2275
      @lillyput2275 4 місяці тому +6

      Yes I watched many times and thought to put this comment and found ur comment 😅

    • @oyeshxrme
      @oyeshxrme 3 місяці тому +1

      yeah bro

  • @MadirajuPhaniSaiSrinivas
    @MadirajuPhaniSaiSrinivas 5 місяців тому +12

    Corrections in video :
    16:46 & 22:51 - Take Smaller One*

  • @Sonu.Singh.28
    @Sonu.Singh.28 4 місяці тому +23

    Simple thought process: On top a building we can store some water if the there is a building on both left and right with height greater than the current building. And the amount of water stored on top of the building would be the min height of those left and right building minus the height of current building.

    • @anujbalwada5211
      @anujbalwada5211 3 місяці тому +2

      Thanks a lot bro 🤗
      with this single thought , I have implemented it easily .

  • @kartiksaini-xn6ke
    @kartiksaini-xn6ke 6 місяців тому +27

    16:46, arr[i] has to be *smaller* than and NOT greater than leftMax and rightMax to store water on top of it

  • @subratkumarsahoo3785
    @subratkumarsahoo3785 6 місяців тому +85

    Totally confused in the better approach!!😢I think the bruteforce approach is better..

    • @farchit9467
      @farchit9467 5 місяців тому +7

      if h[l] < h[r], meaning the right can handle the water thus we don't need to worry about the right half, thus we check the left half if we have a taller building (leftMax) to store water & act accordingly.
      lly for the h[l] > h[r]....
      for h[l] == h[r] move any doesn't matter

    • @chad._life
      @chad._life 3 місяці тому +1

      better is cup cake

    • @sonalidutta825
      @sonalidutta825 3 місяці тому

      read my comment. you'll get the gist of it. 😇

    • @vamsikrishnagannamaneni912
      @vamsikrishnagannamaneni912 3 місяці тому

      @@farchit9467 what does llly mean dude?

    • @jyotikajaichand1982
      @jyotikajaichand1982 2 місяці тому +1

      @@vamsikrishnagannamaneni912 similarly

  • @prasenjitsutradhar3368
    @prasenjitsutradhar3368 2 місяці тому +30

    I want to be honest here-this is probably the first time I’ve struggled to clearly understand Striver’s explanation! 😭😭😭
    Previously, I learned the stack topic from Aditya Verma as Striver’s videos weren’t available then. For all other topics, I’ve relied on Striver and have never found any approach difficult to grasp. However, this time, I barely understood the explanation for the second approach. I would sincerely request Striver to consider re-recording this portion to provide more clarity and replace the existing video.🙏🙏🙏

    • @parasarora5869
      @parasarora5869 Місяць тому +3

      Sometimes we don't understand the why behind someone else's thinking. Give it some time and try yourself to find why it works. I also didn't get this one in the first try. But the more I thought about it, the clearer it became. Also, the first approach of using prefixMax and suffixMax is great and can be used in other problems. All the best and keep improving.

  • @souravmohanty834
    @souravmohanty834 5 місяців тому +16

    The optimal approach would definitely not strike in an interview if not revisited😂

  • @Diya-zb5xu
    @Diya-zb5xu 2 місяці тому +6

    it's stack and queue playlist and you are giving optimal solution of two pointer. way to go . atleast could have given the optimal stack use approach.

  • @HarshKumar-mx9nj
    @HarshKumar-mx9nj Місяць тому +2

    For those who cannot understand approach-2:
    According to the code of second approach given by striver there is mistake in dry run at 22:52 where he chose building of height 2 instead of 1
    I think this was the mistake which made it difficult to understand approach 2

  • @rushidesai2836
    @rushidesai2836 4 місяці тому +3

    The way you explained the second approach is commendable.

  • @KrishnaSingh-rd6pr
    @KrishnaSingh-rd6pr 6 місяців тому +10

    Dropping stack playlist in a queue
    Noice

  • @shikher4559
    @shikher4559 4 місяці тому +7

    Striver heap playlist is needed please!

  • @killerboy2387
    @killerboy2387 6 місяців тому +9

    Striver we want Heap playlist its important in intership round there is question of heap

  • @bilalshaikh5648
    @bilalshaikh5648 6 місяців тому +9

    hey Striver hope you are doing extremely. Just had a small request to update these video links on the take U forward A2Z DSA sheet.

  • @AyushEditz-hs6pf
    @AyushEditz-hs6pf 4 місяці тому +16

    Why is this in stack and queue playlist? Shouldn't this be int the 2 pointer and Sliding window playlist??

  • @sujalthakkar2118
    @sujalthakkar2118 2 місяці тому +2

    22:51 - shouldn't we have to take the smaller one here? please correct it. and in the portion of describing the intuition of Optimal approach as well, you said that arr[i] will always have to be greater where it's the opposite. thank you concept was crystal cleared 💌💌

  • @ugthesep5706
    @ugthesep5706 6 місяців тому +5

    Learned a new approach I didn't know the second approach previously. I solved this problem by approach 1 on my own a few weeks ago♥

  • @hashcodez757
    @hashcodez757 6 місяців тому +22

    bhai na toh stack use hua na hi queue
    🥲😅

  • @KeerthiReddyKolan
    @KeerthiReddyKolan 6 місяців тому +32

    But neither stack nor queue is used? 🤔🤔

    • @Ekam873
      @Ekam873 5 місяців тому

      did one thing i traverse from the left and find next greater or equal element except for zero and then we can subtract indexs -1 and that will give the unites of water logged and sum it up that's how you will be using stack to find next smaller element

    • @Aksht-h9u
      @Aksht-h9u 5 місяців тому

      @@Ekam873 can you explain more or share your code please

  • @AkshayVaghela-o9c
    @AkshayVaghela-o9c 6 місяців тому +6

    22:57 l=1 and r=2 then why you choose r=2 we have to choose smaller one right ??

  • @prathamesh009m
    @prathamesh009m 5 місяців тому +3

    I strongly advise that if not understood Better Approach then Dry run of pseudo code..

  • @apmotivationakashparmar722
    @apmotivationakashparmar722 4 місяці тому

    Thank you Striver for great explaination 😀🙏

  • @Sanyam7208
    @Sanyam7208 3 місяці тому +2

    Doubt
    Ye pure process me stack kaha use hua jo ye stack ka topic ha

  • @callmesumant
    @callmesumant 3 дні тому

    this question should have been in the array problems playlist as there is no implementation of either stack or queue.
    Also, the optimised solution if quite confusing to understand.. can you simplify it further?

  • @Gurunat16
    @Gurunat16 5 місяців тому +6

    For better understanding, consider L, R, (either of) leftMax or rightMax as buildings (Building of 3).....
    To trap water it should satisfy any one of the combinations...
    leftMax > L < R
    L > R < rightMax
    Remember you always first look at the L and R. Then decide which one to choose among leftMax or rightMax.
    Next doubt might be, how it works for same L and R...
    If L == R, then we can apply it to both of the above combinations.
    leftMax > L == R -> Wont be valid.... Because leftMax cannot be greater than R (Thats how we iterate thru the arr). Same way for another combination as well.

  • @oyeshxrme
    @oyeshxrme 3 місяці тому +2

    optimal solution 🤐

  • @arnavjain6038
    @arnavjain6038 5 місяців тому

    Please link problem on code 360 in description. Great Video as always!

  • @swarupdas4114
    @swarupdas4114 2 місяці тому +1

    Optimal Solution 15:40

  • @samiranroyy1700
    @samiranroyy1700 5 місяців тому

    sir Understood
    Nice Explanation🥰🥰

  • @Ekam873
    @Ekam873 5 місяців тому +1

    i did one thing i traverse from the left and find next greater or equal element except for zero and then we can subtract indexs -1 and that will give the unites of water logged and sum it up that's how you will be using stack to find next smaller element

    • @zenmonk29
      @zenmonk29 5 місяців тому

      i did the same.but code is a bit errenous. can u share the code please

    • @esmamanyt7048
      @esmamanyt7048 2 місяці тому

      my thought process was same but fucked up while writing code

    • @Ekam873
      @Ekam873 21 день тому

      @@zenmonk29 hi i believe my approach will not work bcz we nedd greatest on right not greater

    • @Ekam873
      @Ekam873 21 день тому

      @@esmamanyt7048 hi i believe my approach will not work bcz we nedd greatest on right not greater

  • @premkulkarni7578
    @premkulkarni7578 Місяць тому

    class Solution {
    public:
    int trap(vector& nums) {
    int n = nums.size();
    // 1st step
    vector prefixmax(n);
    prefixmax[0] = nums[0];
    for (int i=1 ; i=0 ; i--){
    suffixmax[i] = max(suffixmax[i+1] , nums[i]);
    }
    // 3rd final step
    int answer = 0;
    for (int i=0 ; i

  • @kaichang8186
    @kaichang8186 3 місяці тому

    understood, thanks for the perfect explanation

  • @sibiranganath
    @sibiranganath 5 місяців тому +1

    why is this problem is under stack and queue playlist

  • @scruffymakaveli6870
    @scruffymakaveli6870 2 місяці тому

    I have a question Striver, why is this in your stack and queue playlist? We didn't use any stack or queue to solve this problem

  • @Adarsh_agrahari
    @Adarsh_agrahari 5 місяців тому

    thanks u bhaiya for this quality content

  • @chad._life
    @chad._life 3 місяці тому

    but i just want to say your explanation is best out of all ............

  • @DhananjayKumar-rr3jc
    @DhananjayKumar-rr3jc 5 місяців тому

    Amazing optimal solution

  • @godthunderbolt2190
    @godthunderbolt2190 Місяць тому +1

    I tried to solve the Trapping Water -II with this approach but it failed on 19 test case
    Tell me where I am doing wrong
    class Solution {
    public:
    int trapRainWater(vector& heightMap) {

    // Here I have to see max for each side
    int m=heightMap.size(); // no of rows
    int n=heightMap[0].size(); // no of columns
    vectorleftrowwisemax(m,vector(n,0));
    vectorrightrowwisemax(m,vector(n,0));
    vectoruppercolwisemax(m,vector(n,0));
    vectordowncolwisemax(m,vector(n,0));
    for(int i=0;i

  • @vamsikrishnagannamaneni912
    @vamsikrishnagannamaneni912 2 місяці тому

    Why are we incrementing the smaller one in O(1) SC approach?

  • @sauravfarkade1928
    @sauravfarkade1928 6 місяців тому +2

    Understood!!
    cout

  • @swadhinsahoo2846
    @swadhinsahoo2846 5 місяців тому

    16:46 it has to be smaller not greater

  • @santoshkumarag727
    @santoshkumarag727 Місяць тому

    One quick question here, 1st approach pre computation(prefix/Suffix). 2nd approach two pointer. Why this has been tagged in stack or queue playlist. Any thoughts?

  • @mohanappriyakarunakaran
    @mohanappriyakarunakaran 3 місяці тому

    Fine but where do we use stack ir queue here🤔

  • @omkarshendge5438
    @omkarshendge5438 6 місяців тому +1

    arr[i] has to be strictly less than leftmax and rightmax this is the correction folks pls take care of.

  • @KarumuriYasaswini
    @KarumuriYasaswini 3 місяці тому

    optimal soln 😵

  • @pranaymishra5456
    @pranaymishra5456 4 місяці тому

    why this video is in stack and queue playlist?
    There is no use of stack or queue

  • @udaypaul77
    @udaypaul77 5 місяців тому

    great explanation

  • @aashikroy2198
    @aashikroy2198 3 місяці тому

    Solution using Stack :
    public static long getTrappedWater(long []height, int n) {

    long totalWater = 0;

    Stack stack = new Stack();

    for (int i = 0; i < n; i++) {

    while (!stack.isEmpty() && height[i] > height[stack.peek()]) {
    int bottom = stack.pop(); // Index of the bar at the bottom

    if (stack.isEmpty()) {
    break;
    }

    int left = stack.peek();
    int right = i;

    int width = right - left - 1;
    long heightOfWater = Math.min(height[left], height[right]) - height[bottom];

    totalWater += width * heightOfWater;
    }


    stack.push(i);
    }

    return totalWater;

  • @KartikeyTT
    @KartikeyTT 6 місяців тому +3

    ye stack and queue ka question to nhi h fir is playlist me kyu h

  • @AyanAbbas-ps8xv
    @AyanAbbas-ps8xv 6 місяців тому +7

    for the very first time solved a hard problem in a single go

  • @mayukhbhowmik934
    @mayukhbhowmik934 2 місяці тому

    Bro Made stack question a two pointer question!!!

  • @MuraliSriramula-lm4zt
    @MuraliSriramula-lm4zt 3 місяці тому

    where does stack used here?

  • @nikhiljain-nl7rs
    @nikhiljain-nl7rs 5 місяців тому

    if condition is not needed in the last loop

  • @n5678--
    @n5678-- 4 місяці тому

    Isme stack queue ka use kahan hua??

  • @OmPrasad-x9u
    @OmPrasad-x9u 6 місяців тому

    Nice Explanation

  • @aashikroy2198
    @aashikroy2198 3 місяці тому

    I thought he would explain the approach by using stack as well.

  • @samiranroyy1700
    @samiranroyy1700 5 місяців тому

    class Solution {
    public int trap(int[] height) {
    int n= height.length;
    int left[]= new int[n];
    int right[] = new int[n];
    left[0]=height[0];
    for(int i=1;i=0;j--)
    {
    right[j]=Math.max(right[j+1],height[j]);
    }
    int ans=0;
    for(int y=0;y

  • @Sridhar-fd5qr
    @Sridhar-fd5qr 3 місяці тому

    Dry run, you will understand the intuition

  • @AmandeepSingh-rd6ql
    @AmandeepSingh-rd6ql 6 місяців тому +1

    Why traversing the smaller one someone can tell .?

    • @dhruvkhanna2410
      @dhruvkhanna2410 5 місяців тому

      if you traverse the greater one, how can you store the water? draw a curve for the array and think....you will understand!

    • @dhruvkhanna2410
      @dhruvkhanna2410 5 місяців тому

      i will look like a container

    • @AmandeepSingh-rd6ql
      @AmandeepSingh-rd6ql 5 місяців тому

      @@dhruvkhanna2410 thanks bro for the help

  • @Bhargob_Lahon
    @Bhargob_Lahon 4 місяці тому

    stack toh use hi nhi ho rha , toh stack playlist me kiu h ye

  • @gautamsaxena4647
    @gautamsaxena4647 2 місяці тому

    understood bhaiya

  • @themusicguy539
    @themusicguy539 6 місяців тому +1

    void lefty(vector&height,vector&prefix){
    prefix[0]=height[0];
    for(int j=1;j=0;j--){
    suffix[j]=max(height[j],suffix[j+1]);
    }
    }
    int trap(vector& height) {
    int total=0;
    int n=height.size();
    vectorprefix(n);
    vectorsuffix(n);
    lefty(height,prefix);
    righty(height,suffix);
    for(int i=0;i

  • @rishabhkansal5811
    @rishabhkansal5811 6 місяців тому

    Why in l and r we always choose smaller building?

    • @rallapatijayasailakshmi1585
      @rallapatijayasailakshmi1585 6 місяців тому +1

      the basic equation for calculating the water is water = Min (leftMax,RightMax) - currentHeight , since we are choosing the min of left and right , we are only intrested in getting the smaller building always

  • @sonalidutta825
    @sonalidutta825 3 місяці тому +4

    if you understood the prefix/sufix approach, you'll get the 2pointer approach as well !!!!
    1. why L and R meet at the highest height?
    -> since we are processing left/right side based on whichever is the smallest.
    at some index Left_max is less than Rightt_max => process left , update Left_max
    now as soon as Left_max becomes greater than Rightt_max => start processing right, update Rightt_max....continue
    2. why 2 pointer?
    amount = min(Left_max,Rightt_max) - curr_height; (and amount should be greater than 0 obvoiusly!)
    from prefix and suffix logic:
    min(Left_max,Rightt_max) => if at some point Left_max is minimum then for any next index right_max can be minimum only when left_max is updated to a bigger value.
    note: values of Left_max & Rightt_max can't be reduced. we are taking minimum out of bigger and bigger.
    coming to 2ptr
    now for any index L from start (i.e left) I need min(Left_max, Rightt_max).
    suppose for that index left_max till L-1 is less than right_max till some index R.
    do u think we need to calculate right_max till L+1 knowing that value of right_max won't reduce and we need the min(Left_max,Rightt_max).
    answer is no.
    Reason?
    -> right_max is only going to increase. so the left_max is already the minimum. then why the heck you'd calculate right_max till L+1 , isn't it great?
    happy coding!!🙌🏼☺

    • @sonalidutta825
      @sonalidutta825 3 місяці тому

      class Solution {
      public:
      int trap(vector& height) {
      int n = height.size();
      int l=0, r=n-1, l_max=0,r_max=0, ans=0;
      while(l

  • @lokesh8660
    @lokesh8660 4 місяці тому

    How can we do it using just the suffix sum

    • @shoaibmalik0019
      @shoaibmalik0019 Місяць тому

      By maintaining a variable that stores the leftmax and is updated while traversing from left to right

  • @firebout7675
    @firebout7675 4 місяці тому

    class Solution {
    public:
    int trap(vector& h) {
    vector left(h.size(), 0);
    vector right(h.size(), 0);
    int maxi = INT_MIN;
    for(int i=0; i maxi){
    maxi = h[i];
    left[i] = maxi;
    }
    else{
    left[i] = maxi;
    }
    }
    maxi = INT_MIN;
    for(int i=h.size()-1; i>=0; i--){
    if(h[i] > maxi){
    maxi = h[i];
    right[i] = maxi;
    }
    else{
    right[i] = maxi;
    }
    }
    int ans =0;
    for(int i=0; i

  • @chitranshverma1822
    @chitranshverma1822 6 місяців тому

    for the first approach which should have been easier was not able to code it up on leetcode....its just soo hard, it throws runtime error to me ....i know that i must be putting some minute error but still i am crying in tears and frustrated as hell
    PS- i am sitting and doing this question since 2 hours now

    • @themusicguy539
      @themusicguy539 6 місяців тому

      void lefty(vector&height,vector&prefix){
      prefix[0]=height[0];
      for(int j=1;j=0;j--){
      suffix[j]=max(height[j],suffix[j+1]);
      }
      }
      int trap(vector& height) {
      int total=0;
      int n=height.size();
      vectorprefix(n);
      vectorsuffix(n);
      lefty(height,prefix);
      righty(height,suffix);
      for(int i=0;i

    • @madhu_mohanreddy
      @madhu_mohanreddy 6 місяців тому

      second approach is better

    • @KUMARSAURABH-s5i
      @KUMARSAURABH-s5i 6 місяців тому

      for vectors use pass by reference

    • @abhishekc3556
      @abhishekc3556 5 місяців тому

      class Solution
      {
      public:
      int trap(vector &height)
      {
      int n = height.size();
      if (n == 0)
      return 0;
      int left[n];
      left[0] = height[0];
      int i = 1;
      while (i < n)
      {
      left[i] = max(left[i - 1], height[i]);
      i++;
      }
      int rightMax = INT_MIN;
      int totalWater = 0;
      for (int i = n - 1; i >= 0; i--)
      {
      rightMax = max(rightMax, height[i]);
      totalWater += min(left[i], rightMax) - height[i];
      }
      return totalWater;
      }
      };

  • @GeetainSaar
    @GeetainSaar 7 днів тому

    Where is stack bhaiya ❤

  • @SapanaDashoni
    @SapanaDashoni 4 місяці тому

    Definitely unable to make better approach at interview

  • @sanketatmaram
    @sanketatmaram 4 місяці тому

    understood!

  • @ddevarapaga5134
    @ddevarapaga5134 5 місяців тому +1

    Understood

  • @JITESHSINGH-l7d
    @JITESHSINGH-l7d Місяць тому

    Is it not a 2 pointer rather than stack 😂

  • @devireddysaikumarreddy4772
    @devireddysaikumarreddy4772 Місяць тому

    Plse pop() this video from the stack playlist 😂

  • @KartikeyTT
    @KartikeyTT 6 місяців тому

    tysm sir

  • @AkOp-bf9vm
    @AkOp-bf9vm 4 місяці тому +2

    i have a question ... we done both approach without stack then why this question is in stack playlist??

  • @DeadPoolx1712
    @DeadPoolx1712 3 місяці тому

    UNDERSTOOD;

  • @subee128
    @subee128 6 місяців тому

    Thanks

  • @THOSHI-cn6hg
    @THOSHI-cn6hg 5 місяців тому

    two pointer approach is better

  • @aayush5474
    @aayush5474 3 місяці тому

    aadhe ghante ki video dekhli na stack use hua na queue

  • @abdelfattahmohamed3512
    @abdelfattahmohamed3512 20 днів тому

    Please review the video before releasing it, as every video usually contains at least one mistake

  • @Ayush37262
    @Ayush37262 6 місяців тому

    Why this question is marked as hard on leetcode??

    • @subhajitdey135
      @subhajitdey135 5 місяців тому +2

      because its hard man :) prolly due to the optimal approach

  • @sibiranganath
    @sibiranganath 5 місяців тому

    daam man

  • @gaminghouse7861
    @gaminghouse7861 5 місяців тому +3

    explanation is not too good , begineer will never git it.

  • @GaneshBhutekar-nu1gd
    @GaneshBhutekar-nu1gd 3 місяці тому

    thanks

  • @aryankumar3018
    @aryankumar3018 5 місяців тому

    Understood

  • @rutujashelke4208
    @rutujashelke4208 4 місяці тому

    Understood

  • @abhinavabhi3568
    @abhinavabhi3568 Місяць тому

    Understood