Count Subarray sum Equals K | Brute - Better -Optimal

Поділитися
Вставка
  • Опубліковано 22 сер 2024

КОМЕНТАРІ • 244

  • @itzmartin20
    @itzmartin20 11 місяців тому +136

    When I first started DSA, I was just so scared of the code and knowing very little about the logic and the intuition behind but Striver you are the one who has ever showed the completely difference - Extreme natural approach and observation and crystal clear logic. You've made the coding fun and interesting toward people like me. Hats off for your dedication! Understood!

    • @utkarshverma3314
      @utkarshverma3314 11 місяців тому +5

      i am doing his dsa sheet , the array part and almost every question has a completely different logic and approach and its becoming quite frustrating as im not able to come up with the solutions so do i just keep solving more problems or am i doing something wrong

    • @anshlyk
      @anshlyk 11 місяців тому

      keep going! I was in the same boat, you'll slowly be able to form logic@@utkarshverma3314

    • @akworld2739
      @akworld2739 10 місяців тому

      @@utkarshverma3314 same problem i am also facing

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

      ashishbhattacharyya yup, it works for me.

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

      could you please tell if i should make notes ?? how do i make them so that i dont put hours in it

  • @daayush6654
    @daayush6654 Рік тому +45

    I saw this video at around 10 am in college, was only able to think of o(n²) solution, I took the pause at your hint of using prefix sum array, kept thinking for some time while in college lectures but was able to get the solution at around 6pm 😝, I know it took time but it felt good to actually think of the solution, please keep up the consistency

  • @AyushVerma-wu3nn
    @AyushVerma-wu3nn 11 місяців тому +14

    Just when I think the video is getting long enough for a simple problem,
    I go search the web and find not a single tutor with such a powerful explanation!

  • @andrewcenteno3462
    @andrewcenteno3462 Рік тому +34

    This man is my hero, I struggled so much with this question to visualize it and subsequent problems like it. I've done ove 270 LC questions, but this man made it so simple

  • @gamerversez5372
    @gamerversez5372 Рік тому +11

    Instead of adding 0 in the hashmap, we can just use the statement if(sum==k) ans++; That works fine.
    See the Below Code
    int subarraySum(vector& nums, int k)
    {
    int ans=0;
    unordered_map x;

    int sum=0;

    for(int i=0;i

    • @00RohitRoshan
      @00RohitRoshan Рік тому +3

      very good .

    • @00RohitRoshan
      @00RohitRoshan Рік тому +1

      ` if(x.find(sum-k)!=x.end()) ans+=x[sum-k]; `
      And why this check before incrementing and.
      class Solution {
      public:
      int subarraySum(vector& nums, int k)
      {
      int ans=0,sum=0;
      unordered_map x;
      for(int i=0;i

    • @kushalswarup2662
      @kushalswarup2662 11 місяців тому

      brilliant

  • @abhijeetmishra3804
    @abhijeetmishra3804 10 місяців тому +7

    understood bhaiya . You can not even imagine how much people love u and praise you and speak about your videos all the time. I am sure u get hiccups every now and then . Live long bhaiya u are our real teacher.

  • @aryansinha1818
    @aryansinha1818 Рік тому +22

    You have given more than anyone can ask for. Thank you for all your support and such amazing videos. They are really helpful. Just a small thing can we have a dark mode setting for "take you forward" pages.

    • @takeUforward
      @takeUforward  Рік тому +24

      You can build one chrome extension may be ;)

    • @dom47
      @dom47 Рік тому +22

      appreciates striver by telling "u have given more than anyone can ask" and proceeds to place demand .

    • @yashjoon3889
      @yashjoon3889 Рік тому +4

      @@takeUforward lol would be a good project for the resume?

    • @manvinmusic9239
      @manvinmusic9239 Рік тому +4

      striver actually give the dark mode option

  • @AnuroopLSabu-mp8wm
    @AnuroopLSabu-mp8wm Рік тому +7

    Its really amazing that you are taking your time in explaining via the dry run. It helps me a lot. Thanks :)

  • @user-fn2jg7ng7q
    @user-fn2jg7ng7q Рік тому +3

    I saw many times but I couldn't understand...But now i finally understood and realised that ur explaination is too good...!

  • @puneetnj
    @puneetnj Рік тому +16

    So here, if in the question it is stated that it contains only positive as in codestudio then we can apply 2-pointer(Sliding window) as done in longest subarray with sum k. TC: O(N) SC: O(1)
    Else, if it contains both positive and negative HashMap is optimal

  • @Anurag-fk3op
    @Anurag-fk3op 4 місяці тому +12

    16:29 if we write if(sum==k) count++
    We don't need to include 0 at beginning

  • @Someone-k4d
    @Someone-k4d 10 днів тому

    What an excellent explanation! Even after watching another video 6-7 times, l could not understand it. But understood this perfectly after watching only once!

  • @neerajkumar-ts6om
    @neerajkumar-ts6om 12 днів тому

    I think I should watch it again, have watched a lot of your video this is the first which I didn't understand in the first go.

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

    Struggled to understand this solution, now understood, Keep up the great work Striver

  • @Manishgupta200
    @Manishgupta200 Рік тому +6

    That's really amazing 🤩Striver! code is too sort but logic is superb for the optimal. from brute (TC-> O(N^2), SC -> O(1)) to optimal (TC -> O(N) when using unordered_map, O(N * log N) when using ordered map, SC -> O(N) for using map data structure.

  • @alishashaikh3859
    @alishashaikh3859 Рік тому +1

    Thank you so much. I saw many other youtuber's video but this video is the best . I was able to understand after watching this video for 2 times

  • @infernogamer52
    @infernogamer52 Рік тому +2

    Understood Bhaiya! This was a tough one to understand for me...will soon revisit it
    Thank you🙏

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

    This explanation is so 100x better than Neetcode's. Thank you !!!

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

    The sliding window approach actually performs better with O(n) time complexity.
    int subarraySum(vector& nums, int sum) {
    int count = 0;
    int currSum = 0;
    unordered_map sumFreq;
    for (int i = 0; i < nums.size(); ++i) {
    currSum += nums[i];
    if (currSum == sum)
    count++;
    if (sumFreq.find(currSum - sum) != sumFreq.end())
    count += sumFreq[currSum - sum];
    sumFreq[currSum]++;
    // If currSum becomes greater than sum,
    // subtract elements from the start
    while (currSum > sum) {
    currSum -= nums[i - count + 1];
    sumFreq[currSum]--;
    if (sumFreq[currSum] == 0)
    sumFreq.erase(currSum);
    count--;
    }
    }
    return count;
    }

  • @mehulthuletiya5638
    @mehulthuletiya5638 Рік тому +10

    Timestamps
    01:03 - Problem Statement
    01:13 - Sub-array definition
    01:52 - Example
    03:13 - Brute force solution
    06:07 - Complexity
    06:29 - Better solution
    08:07 - Complexity
    08:21 - Optimal Solution
    08:41 - Prefix sum concept
    09:35 - Example
    13:55 - Dry run
    21:22 - Code
    22:38 - Complexity

  • @user-yb1es6mu8g
    @user-yb1es6mu8g 11 місяців тому +1

    Amazingly Understood, Thank you for such a in depth thought process

  • @pulkitgupta669
    @pulkitgupta669 11 місяців тому +1

    Understood Striver ❤. You are a living legend sir. 🤩🤩

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

    Was able to think O(N^2) approach and totally underatood optimal solution too 😊

  • @rushabhajain3977
    @rushabhajain3977 9 місяців тому +1

    Excellent explanation yaar! Great to see such kind of explanations that guide from brute force to optimised solution in such a detail! Thank you so much and keep making such great videos :)

  • @cinime
    @cinime Рік тому +1

    Understood! Super fantastic explanation as always, thank you very very much for your effort!!

  • @nikiteshnandale8264
    @nikiteshnandale8264 Рік тому +5

    It seems like you have edited your voice in the video and made it soft, I am missing that bold voice which is there in the DP playlist. Please don't edit your voice, you don't have to adjust yourself for us. We like the way you are, the original STRIVER🔥🔥

    • @takeUforward
      @takeUforward  Рік тому +13

      But we need to look at the future, we want to go global, so audio quality has to be maintained, I hope you get that :)

    • @abdulrehmaan153
      @abdulrehmaan153 Рік тому

      ​@@takeUforwardand we love you for that too,
      It's sort of unconditional 😂

    • @spartaninfo3273
      @spartaninfo3273 17 днів тому

      Banee...

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

    for me optimal is little hard but after see 2-3 time video , got easly understand

  • @AmanThakur-ve6ji
    @AmanThakur-ve6ji Рік тому +1

    God for beginner❤hats of u bhaiya

  • @code710
    @code710 Рік тому +6

    Hi bhaiya it would be really helpful if you can give similar question links for practise after every question explanation!!

  • @RaviKumar-sn6tu
    @RaviKumar-sn6tu 4 місяці тому +1

    understood captain...thanks

  • @GarimaShukla-jq8sf
    @GarimaShukla-jq8sf Місяць тому

    Striver you are great 🙌🙌 .I just want to thank you ❤️.

  • @vidhanshuborade5977
    @vidhanshuborade5977 Рік тому +2

    Excellent explanation, understood ! ✨

  • @nopecharon
    @nopecharon Рік тому +1

    you are topG of DSA

  • @dayashankarlakhotia4943
    @dayashankarlakhotia4943 Рік тому +1

    Previous explanation and current explanation is good .understood

  • @krishnavamsiyerrapatruni5385
    @krishnavamsiyerrapatruni5385 Рік тому +1

    Understood. Thank you so much!

  • @vishnupandey3390
    @vishnupandey3390 Рік тому

    thanks striver you have really explained this so well
    god bless you
    you are a wonderful teacher for many 🙏🙏

  • @mriduljain1981
    @mriduljain1981 Рік тому

    we can also use sliding window 2 pointer approach for this one code->
    int findAllSubarraysWithGivenSum(vector < int > & arr, int k) {
    int n =arr.size(),sum = 0,cnt = 0,left = 0;
    for(int right = 0;right k) sum-=arr[left++];
    if(sum == k) cnt++;
    }
    return cnt;
    }

    • @amitranjan6998
      @amitranjan6998 11 місяців тому

      It will fail .arr[]=[1] k=0

    • @mriduljain1981
      @mriduljain1981 11 місяців тому

      @@amitranjan6998 yes we just need to add a condition of left

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

    Thank you Striver. I owe you❤

  • @Hustler0109
    @Hustler0109 Рік тому +5

    Striver you can make these playlists a bit fun if you allow your viewers to suggest you problems they think discussable !!
    btw loving the playlist

  • @ashj1165
    @ashj1165 7 місяців тому

    though I am still figuring out on the map[0]=1 part but surely the rest of the part was indeed clear. thanks for these videos.

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

      if you select no element in sub array then , map[0]=1

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

    you are awesome bhaiya...

  • @schan263
    @schan263 9 місяців тому

    Thanks for the great video. I don't see how I can come up with the optimal solution during the interview without hint from the interviewer.

  • @varunpalsingh3822
    @varunpalsingh3822 Рік тому +1

    Really good explanation & kudos to efforts, understood 👍

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

    mpp[0] = 1 helps us to take the count when (sum == k ). Because when sum will be k, then remove will be 0. And then mpp[1] will give us 0, which will be added to the count. If we don't store 0 to our map. then we need to handle the case in an extra if condtion. which is if(sum == k) count++;

  • @opgaming-sl8ze
    @opgaming-sl8ze Рік тому

    Bhaiya ye Question ka video dekhne se phale hoo gaya 😁😁Only Minor change
    int findAllSubarraysWithGivenSum(vector < int > & nums, int k) {
    int right = 0;
    int left = 0;
    int count = 0;
    long long sum = nums[0];
    int n = nums.size();
    while(right < n){
    while(left k){
    sum = sum - nums[left];
    left++;
    }
    if(sum == k){
    count++;
    }
    right++;
    if(right < n){
    sum+=nums[right];
    }
    }
    return count;
    }

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

    Storing (0,1) in the hashmap is bit confusing, instead we can just increase a check i.e. if(currSum == k) count++. The more readable code(JAVA) will look like this:
    public int subarraySum(int[] nums, int k) {
    int currSum = 0, count = 0;
    int n = nums.length;
    HashMap map = new HashMap();
    for(int i=0; i

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

    Without adding to map, you need to count occurrences still not in map
    public int subarraySum(int[] nums, int k) {
    int sum=0;
    int count =0;
    Map map = new HashMap();
    for(int i=0;i

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

    Regarding putting (0,1) int the Hashmap initally :
    Let consider somehow the preSum got exactly equal to our k, means now the sub-array till that presum element gives us the k (~ preSum-k = 0).
    means whenever we find our preSum touching the k value, we need to increment count but we will not be able to find it in hashMap as it is yet to be inserted that why
    either increment count based on if preSum-k = 0 or put a (0,1) in hashmap to automatically finding preSum-k = 0 in the hashMap.
    int preSum = 0, count = 0, start = 0;
    Map mp = new HashMap();
    for(int i=0;i

  • @kunwar-nw5dd
    @kunwar-nw5dd Рік тому

    solution blew my mind

  • @ayanangshudasmajumder112
    @ayanangshudasmajumder112 Рік тому +4

    if instead of specifying map[0]=1 in the beginning if we give a condition that if(preSum == k) { count ++;}
    Will it be correct Striver bhaiya??

  • @VineetKumar-fk2rl
    @VineetKumar-fk2rl 9 місяців тому +1

    We can also solve this problem in O(1) space complexity but the T.C will be 2N using two pointer approach.

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

    Thanks for the help raj bhaiya

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

    Awesome explanation, one approach of sliding window will not work in this problem if array contains negative elements also.

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

    Understood, thank you.

  • @user-du1uj3wk7g
    @user-du1uj3wk7g Місяць тому +2

    i still don't get the significance of (0,1) in the map, my answer still got submitted in Leetcode.

  • @rajatpatra2593
    @rajatpatra2593 Рік тому +2

    Understood ❤️

  • @gamengoaituyen4432
    @gamengoaituyen4432 Рік тому

    tks for explanation, you are savior

  • @sukhpreetsingh5200
    @sukhpreetsingh5200 Рік тому

    Understood💖amazing explanation

  • @harshilpatel3205
    @harshilpatel3205 19 днів тому

    Understood 🙏🏻

  • @thebusinesspostt
    @thebusinesspostt Рік тому +15

    are we supposed to think of optimal solution on our own. asking because it seems pretty daunting.

    • @takeUforward
      @takeUforward  Рік тому +12

      Its not daunting, it is basically a technique, on the basis of this you can solve many questions

    • @RajeevCanDev
      @RajeevCanDev Рік тому

      Literally, maybe just because I'm watching while I'm not in complete attention but still the optimal approach feels like it comes with a completely different path as compared to normal intuitive thought process

  • @AniketKumar-hf2bo
    @AniketKumar-hf2bo 6 місяців тому

    understood ,thnx for amazing video ❤❤❤❤❤❤

  • @UtkarshSingh575
    @UtkarshSingh575 4 місяці тому +1

    Understood!

  • @sauravchandra10
    @sauravchandra10 Рік тому

    Understood, thanks!

  • @reshusingh3558
    @reshusingh3558 Рік тому

    understood sir ,great explanation

  • @meghnakhaitan2495
    @meghnakhaitan2495 Рік тому +1

    Can you pls pls plsssss do strings before binary search next plsss🙏 ? From 2023 batch🥺. Wish we could have the entire series in our 1st 2nd 3rd yrs

  • @AnkitKumar-sz3by
    @AnkitKumar-sz3by 11 місяців тому

    thanks really good explination

  • @JK-de2gh
    @JK-de2gh 16 днів тому +1

    understood

  • @lakshmiprasanna7058
    @lakshmiprasanna7058 Рік тому +1

    Understood 💯💯💯

  • @mohitsingh13
    @mohitsingh13 23 дні тому

    Understood ❤

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

    Thanks bro. Understood

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

    Awesome Awesome Sir...............

  • @NitinKumar-wm2dg
    @NitinKumar-wm2dg Рік тому

    Thanks bhaiya, understood

  • @culeforever5408
    @culeforever5408 10 місяців тому +1

    undestood ✌

  • @user-sm7zo5zd9t
    @user-sm7zo5zd9t 6 місяців тому +1

    Understood

  • @swapnilingale4164
    @swapnilingale4164 11 місяців тому

    Nice explation ❤

  • @kingbadshah452
    @kingbadshah452 7 місяців тому

    understood striver thanks

  • @gagan_.hegde14
    @gagan_.hegde14 3 місяці тому

    underrstood

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

    very nice. .thankyou

  • @user-sp8ne7hj3n
    @user-sp8ne7hj3n 9 місяців тому

    nice ..........explanation

  • @Indiiaa744
    @Indiiaa744 2 дні тому

    Bro u are looking like virat ❤

  • @user-ed8bc2hg5o
    @user-ed8bc2hg5o 27 днів тому

    Understand

  • @parshchoradia9909
    @parshchoradia9909 Рік тому

    Understood Sir!

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

    thank you so much

  • @sahilnayak9000
    @sahilnayak9000 7 місяців тому


    You mentioned performing a dry run on the array [3, -3, 1, 1, 1] to understand the significance of initially putting (0, 1) in the map. However, it hasn't been specified which sum we should consider for this particular dry run.

    • @sahilnayak9000
      @sahilnayak9000 7 місяців тому

      Although i understood,
      if we didn't want to put initially that or if we find it challenging to understand its significance.
      there is an alternative approach to handle the situation.
      Another way is when currentSum - given_sum == 0 we just need to increment counter.
      that's it we can omit to put initially (0,1) pair in map.

  • @moningichandrasekhar7611
    @moningichandrasekhar7611 10 місяців тому

    UNDERSTOOD

  • @RahulGuptaa29
    @RahulGuptaa29 Рік тому +2

    Java code (*_*);
    public int subarraySum(int[] nums, int k) {
    int n = nums.length;
    Map map = new HashMap();
    int res = 0, presum=0;
    map.put(0,1);
    for(int i=0; i

  • @user-uv5or5bm2c
    @user-uv5or5bm2c 6 місяців тому

    Understood.

  • @rakshanaravindran9809
    @rakshanaravindran9809 11 місяців тому

    Thank you!!

  • @her_soulmate
    @her_soulmate 11 місяців тому

    Understood 🎉

  • @tarunsatyarthi4355
    @tarunsatyarthi4355 Рік тому +1

    Easy to understand code
    #include
    int findAllSubarraysWithGivenSum(vector < int > & arr, int k) {
    // Write Your Code Here
    map mpp;
    int sum=0;
    mpp[0]=1;
    int count=0;
    for(int i=0;i

  • @YourCodeVerse
    @YourCodeVerse 10 місяців тому

    Understood✅🔥🔥

  • @user-is6ky7pp2n
    @user-is6ky7pp2n 2 місяці тому

    Understood !! 😍😍

  • @mriduljain6809
    @mriduljain6809 Рік тому

    Can also do like this:
    int subarraySum(vector& nums, int k) {
    unordered_map m;
    int c = 0;
    int s=0;
    for(int i=0;i

  • @piyushnandardhane1432
    @piyushnandardhane1432 Рік тому

    Please also make video for count pairs with given sum and divisible by k

  • @rowgha2710
    @rowgha2710 Рік тому +1

    What if the array contains 0s?

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

    thank you

  • @himadriroy7980
    @himadriroy7980 9 місяців тому

    I just wonder how he writes a piece of code so easily. I just wonder when will I be able to write code in such a way.

  • @anuragroy9045
    @anuragroy9045 Рік тому

    understood!!!

  • @AdityaKumar-ow1rh
    @AdityaKumar-ow1rh Рік тому

    we can also do this problem by sliding window technique

  • @madeupofstarstuff3067
    @madeupofstarstuff3067 Рік тому

    Dronacharya from 21st century!!