Frequency of the Most Frequent Element - Sliding Window - Leetcode 1838

แชร์
ฝัง
  • เผยแพร่เมื่อ 10 ม.ค. 2025

ความคิดเห็น • 138

  • @misoren9645
    @misoren9645 3 ปีที่แล้ว +54

    If someone wants help with the intuition behind the condition, its basically asking from the current sliding window e.g. [1, 2, 4], how much do you need to convert it in [4, ,4 ,4], you would need 4 (nums[r]) times the window length (r - l + 1) - the sum of the current window. So nums[r]*(r-l+1) - sum, if this is affordable with budget k (nums[r]*(r-l+1) - sum

    • @leul1407
      @leul1407 2 ปีที่แล้ว

      Thanks

    • @sahild5953
      @sahild5953 ปีที่แล้ว

      @@leul1407Thanks

    • @Sam-dk5id
      @Sam-dk5id ปีที่แล้ว

      thanks!

  • @rommeltito123
    @rommeltito123 2 ปีที่แล้ว +44

    Excellent. I never thought I would watch coding videos right after waking up in the morning.

    • @Eddie4k
      @Eddie4k 2 ปีที่แล้ว +1

      I find myself in this same morning routine every day now 😆

    • @TacticalDoge101
      @TacticalDoge101 11 หลายเดือนก่อน +1

      same here lmao
      @@Eddie4k

  • @daianabilbao2771
    @daianabilbao2771 2 ปีที่แล้ว +71

    I love these explanation videos but sometimes I'm like... how did you come up with this solution? I feel I cannot come up with these solutions on my own. :(

    • @rishujeetrai5780
      @rishujeetrai5780 10 หลายเดือนก่อน +6

      Don't judge your capabilities till you've solved/tried at least a 100 moderate/hard questions

    • @ashantinyongo7632
      @ashantinyongo7632 10 หลายเดือนก่อน +18

      I’ve come to realize the vast majority people don’t come up with these solutions on their own. It’s implausible, what is more plausible is reading other people’s solutions and developing pattern recognition that helps you solve new problems.

    • @rishujeetrai5780
      @rishujeetrai5780 10 หลายเดือนก่อน

      @@ashantinyongo7632 exactly like when you solve subarray sum problems, you see the first solution then there are over a dozen variation. Same with binary search and other algorithms

    • @SoumodeepChatterjeeIITD-dl6so
      @SoumodeepChatterjeeIITD-dl6so 13 วันที่ผ่านมา

      Watch about the 'leetcode' fallacy' by the neetcode channel... I agree with his opinion

  • @abhayzz03
    @abhayzz03 5 หลายเดือนก่อน +4

    Great Explanation Thanks!, For All the java users out there, make sure you use "long" for total and res, wherever you are doing right - left + 1, make sure to convert it to right - left + 1L, while returning the res, you can typecast it simply by (int) res. Good Luck.

  • @marhawk6468
    @marhawk6468 3 ปีที่แล้ว +115

    There used to be a time I was afraid of leetcode. But thanks to you I no longer am

    • @NeetCode
      @NeetCode  3 ปีที่แล้ว +39

      Haha that's awesome.. I'm sometimes still afraid of LC Hards tho 😱

    • @husler7424
      @husler7424 2 ปีที่แล้ว +2

      @@NeetCode really ??😨😨same here....

    • @prathambhardwaj6797
      @prathambhardwaj6797 ปีที่แล้ว +1

      I wish I could become like you bro, soon enough !!

    • @yourlinuxguy
      @yourlinuxguy 7 หลายเดือนก่อน

      I gave you the 100th like . 💘

    • @marhawk6468
      @marhawk6468 7 หลายเดือนก่อน +1

      @@yourlinuxguy are we soulmates 👉👈

  • @ducthinh2412
    @ducthinh2412 2 ปีที่แล้ว +10

    great video! I just want to mention that for sliding window problem, we (generally) always advance the right pointer, so it's better for the outer loop to be a for loop instead of a while loop. That way you won't have to remember to increment the right pointer at the end.

  • @TheElementFive
    @TheElementFive 2 ปีที่แล้ว +82

    A little far fetched to expect someone to be able to come up with that formula in an interview

    • @minciNashu
      @minciNashu 2 ปีที่แล้ว +9

      This one is a 'sliding window' problem, there a bunch of other patterns to practice. So you kinda know what patterns to expect.

    • @TejaaaaaaReddy
      @TejaaaaaaReddy 11 หลายเดือนก่อน

      But one needs to first figure out that it is a sliding window type problem @@minciNashu

    • @ttrey743
      @ttrey743 8 หลายเดือนก่อน +9

      @@minciNashu The sliding window approach isn't hard to come up with. It's the formula used for the window bound check. I feel like that conditional check is what most people consider the hard part of the problem.

  • @koubbe
    @koubbe 3 ปีที่แล้ว +17

    Recently discovered your channel. Easy to follow explanation, time complexity analysis, code in Python included. What else can we ask for? Please keep doing these videos.

  • @glorious_purp_123
    @glorious_purp_123 5 หลายเดือนก่อน +1

    or to simplify the inequality, (num[r] * windowlen - total < k).The num[r] * windowlen - total gives number of increments needed to make all the elements in that window and we can keep expanding this window until num[r] * windowlen - total > k.

  • @zachyang1041
    @zachyang1041 11 หลายเดือนก่อน +1

    I really like how you explain your thinking process like why are we sorting, why are we using sliding window here.
    Some people just explain the solutions without explaining why we are doing in that way.
    Thank.

  • @antibarcelona2123
    @antibarcelona2123 2 ปีที่แล้ว +13

    for java users, declare the total variable as long and you're good to go;

    • @MGtvMusic
      @MGtvMusic ปีที่แล้ว

      Thanks mate, The total sum exceeds int limit at some point right?

  • @AmitSingh-dc2gz
    @AmitSingh-dc2gz 2 ปีที่แล้ว +8

    how do u arrive at that formula? what was ur thought process?

  • @RajPatel-qg1mm
    @RajPatel-qg1mm ปีที่แล้ว +2

    I came accross so many solution videos for this problem but I didn't understand any of those explanations until it yours. You gave the crystal clear explanation.... thank you so much sir..🙏

  • @ZQutui
    @ZQutui 3 ปีที่แล้ว +9

    please keep up doing these videos, it's extremely helpful.

  • @lalitshah9297
    @lalitshah9297 2 ปีที่แล้ว +29

    Nice explanation but I guess the main question is how to arrive at this intuition/formula in interview setup? I mean, if I am seeing this question first time in interview setup - I am not sure how will I arrive at this formula.

    • @ramansdf
      @ramansdf 2 ปีที่แล้ว +3

      I've figured out this pattern in 15 mins, and I'm not genius. Solved only 150 problems
      If you practice more, it's easy to come up with during the interview

    • @victoriatfarrell
      @victoriatfarrell 3 หลายเดือนก่อน +1

      You build the intuition by practicing other sliding window problems

  • @mahesh_kok
    @mahesh_kok 2 ปีที่แล้ว

    hey @neetcode
    I admit that after seeing 5 back to back sliding window problem
    i attempted this problem on my own
    I was able to find solution to that in my own terms but was unable to make through all the test cases on leetcode
    i got almost 50 percent right test cases
    def maxFrequency(self, nums: List[int], k: int) -> int:
    arr = sorted(nums, reverse=True)
    diff = [0]
    max_ele = arr[0]
    for ele in arr[1:]:
    diff.append(max_ele - ele)
    rep = 0
    res = 0
    for d in diff:
    if rep + d

  • @techwills4619
    @techwills4619 3 ปีที่แล้ว +3

    I first though of doing it with Dynamic programming. Essentially we create a modified array by incrementing a value the original array (as long as k>0) then we get the greatest frequency and recall the function recursively on the modified array. We update the greatest frequency if the recursive call produced a better value. Which results in O(n^k) time and O(n) space

  • @ivandrofly
    @ivandrofly หลายเดือนก่อน

    8:38 - Most important part of the video
    12:55

  • @ersinerdem7285
    @ersinerdem7285 3 ปีที่แล้ว +3

    in Java, need to declare total as long type. Otherwise fails in the latter long test cases.

  • @Chirayu19
    @Chirayu19 ปีที่แล้ว +2

    We can also do this by creating a frequency map. The approach mentioned in the video can be used but I came up with another appraoch.
    Create a frequency map.
    Check the answer for last element (max).
    Now come to the second last element.
    New answer would be the old answer - freq of last element
    + Now we can move the left pointer by (freq of curr element*diff of last and curr element), basically new k

    • @ananyagouda8200
      @ananyagouda8200 ปีที่แล้ว

      hey can you provide a pseudo code/code for this

  • @ManishR-ov2gz
    @ManishR-ov2gz 5 หลายเดือนก่อน +2

    I have one doubt the sliding window condition/formula how do you guys come up with it ? I dont think I can ever look at a problem and just figure out a formula like that

  • @rishabhmalviya331
    @rishabhmalviya331 4 หลายเดือนก่อน

    nums[r] x (windowLen) is basically a hypothetical maximum area you can have with length as nums[r] and breadth as size of the window. Total is the sum of actual areas(each num having breath 1 and length as value of num) in the window. Now we check if hypothetical area - total area is lesser than K(assume K as increasing area of each number by one). If true then we can increase the actual area to be equal to hypothetical one(can only do this by increasing length of each num so that length of each num is equal).

  • @adududuke3995
    @adududuke3995 2 ปีที่แล้ว +1

    What if we start the two pointers from the right after sorting. That way we have a max variable that gets updated. So we increase the value at p2 till equals p1 while K is still available.
    Given ----- 1,2,3,5,7,10 and K = 8, p1 and p2 = 10. p2 moves to 7 ( edge case - if p2 === p2+1, we move p2 again p2-1) and we increase it to 10. K is now left with 5 and Max value is 2. p2 moves to 5 and we can take it to 10. K is now 0 and Max is updated to 3.
    SInce K is used up, we can now reset p1,p2 to 7, reset K to 8 and repeat

  • @jonaskhanwald566
    @jonaskhanwald566 3 ปีที่แล้ว +3

    keep posting. never stop

  • @jabedhasan21
    @jabedhasan21 ปีที่แล้ว +1

    For some test cases, the total sum will overflow if you are writing the code in Java Or CPP. So int that case use this logic
    while (nums[r] * (r - l + 1) - total > k)

    • @harshilsutariya1793
      @harshilsutariya1793 ปีที่แล้ว

      but why ?

    • @yashwanthsai762
      @yashwanthsai762 ปีที่แล้ว

      can u pls explain

    • @aniketv2370
      @aniketv2370 5 หลายเดือนก่อน

      @@yashwanthsai762 because total+k turns out to be a big value which overflows so either typecast it as a long or use this formula

  • @TejaaaaaaReddy
    @TejaaaaaaReddy 11 หลายเดือนก่อน +1

    I guess it is not easy to get this idea in an actual interview.

  • @anandsardesai301
    @anandsardesai301 4 หลายเดือนก่อน

    not sure how its going to work on input in above example like 1,1,1,2... & k = 2. Its saying that max window size is 3 at index = 2. But not sure how k=2 can be distributed to get that frequency.

  • @vaishnavidaber5976
    @vaishnavidaber5976 4 หลายเดือนก่อน

    Such a great explanation. Thank you!

  • @HarshYadav-xe4ff
    @HarshYadav-xe4ff 3 ปีที่แล้ว +1

    Very nice explanation 😀

  • @priyanshumakwana5034
    @priyanshumakwana5034 3 หลายเดือนก่อน

    Guys please correct me if I am wrong, but if we increment both the values of 1s by 1 each, thus exhausting our budget, won't the answer for the greatest frequency come out as 4 ( [ 1, 2, 2, 2, 2, 4] ) ? Since there will be 4 number of 2s now? How is this logic correct then?

  • @iamabishekbaiju
    @iamabishekbaiju ปีที่แล้ว +1

    I was not able to come up with that equation. I found the bruteforce way which of course resulted in TLE. Anyway thanks.

    • @gauravpoharkar9797
      @gauravpoharkar9797 ปีที่แล้ว

      brute force solution does work its given as hint as well

    • @userre85
      @userre85 ปีที่แล้ว

      n

  • @vignesh9678
    @vignesh9678 2 ปีที่แล้ว

    What a logic!!! Loved it.

  • @abhishekkumargupta3605
    @abhishekkumargupta3605 3 ปีที่แล้ว +1

    very good explanation , it's very useful..

  • @stith_pragya
    @stith_pragya 11 หลายเดือนก่อน

    Thank You So Much for this wonderful video.........................🙏🏻🙏🏻🙏🏻🙏🏻🙏🏻🙏🏻

  • @jonaskhanwald566
    @jonaskhanwald566 3 ปีที่แล้ว +3

    Frequency of the Most Frequent Element
    similar problems below. If you have time, explain them too.
    Longest Subarray of 1's After Deleting One Element
    Constrained Subsequence Sum
    Number of Substrings Containing All Three Characters
    Count Number of Nice Subarrays
    Replace the Substring for Balanced String
    Max Consecutive Ones III
    Binary Subarrays With Sum
    Subarrays with K Different Integers
    Fruit Into Baskets
    Shortest Subarray with Sum at Least K
    Minimum Size Subarray Sum

  • @ravisaharan219
    @ravisaharan219 6 หลายเดือนก่อน

    Great Explanation Man!!

  • @sarthakyadav9950
    @sarthakyadav9950 3 ปีที่แล้ว +1

    Dude you are just awesome 🔥🔥🔥

  • @mnekx
    @mnekx 2 ปีที่แล้ว

    Amazing man. Keep up the good work

  • @HarshitNegi-e5p
    @HarshitNegi-e5p 22 วันที่ผ่านมา

    For the input [3, 3, 5, 5, 5, 7] and k = 6, why does the sliding window algorithm not produce the expected output of 6?
    I am expecting the answer to be 6 because, with at most 6 operations, we can increment two 3s to 5 (taking 4 operations) and the 7 to 5 (taking 2 operations). After performing these operations, all elements would become 5, resulting in a frequency of 6.
    Can someone clarify if there's a mistake in my understanding or the implementation?

    • @anandakrishnanp6579
      @anandakrishnanp6579 13 วันที่ผ่านมา

      you are not supposed to decrement the elements , k is the budget available to you only for incrementing the values

    • @HarshitNegi-e5p
      @HarshitNegi-e5p 12 วันที่ผ่านมา

      @@anandakrishnanp6579 oh thanks! but then how would you approach such a problem (where increment and decrement both are allowed)?

  • @billycheung7095
    @billycheung7095 ปีที่แล้ว

    Amazing discovery of this sliding window condition

  • @misoren9645
    @misoren9645 3 ปีที่แล้ว

    Nice video, by the way seeing the time execution distribution, theres a peak faster than the time this solution implemented in C++ took. Is it possible that there is a faster solution?

  • @ajaymishra1511
    @ajaymishra1511 4 หลายเดือนก่อน

    how we can do it with brute force or nested loop + hashing?

  • @martin_labastie
    @martin_labastie ปีที่แล้ว

    7:03 example

  • @sahilnegi2789
    @sahilnegi2789 3 ปีที่แล้ว +1

    I think this que is hard for someone who is doing that que first time .

  • @shantanukumar4081
    @shantanukumar4081 3 ปีที่แล้ว

    Thanks 👍👍👍
    Great explanation

  • @jonasp4682
    @jonasp4682 ปีที่แล้ว

    I'm a noob and for some reason I feel like it'd be easier to start with the right pointer at index len - 1, does that make sense?

  • @Ynno2
    @Ynno2 ปีที่แล้ว

    Do you have any tips for when to stop looking for a solution with a better complexity? I dismissed a bunch of O(n log n) solutions thinking there's probably an O(n) solution, then gave up in frustration and looked at the solutions, only to find O(n log n) is optimal.

    • @aryantarafdar443
      @aryantarafdar443 ปีที่แล้ว

      Get an idea from the time constraints bro.

  • @rohit-ld6fc
    @rohit-ld6fc 2 ปีที่แล้ว +1

    almost impossible to come up with a solution if you have not seen this problem before!

  • @jonaskhanwald566
    @jonaskhanwald566 3 ปีที่แล้ว +1

    nobody can explain it better than you. when was this problem posted? I think recently it was..

  • @manishparab4427
    @manishparab4427 ปีที่แล้ว

    best explanation... I tried to solve this problem but could not figure out its sliding window

  • @abhaypandey2668
    @abhaypandey2668 10 หลายเดือนก่อน

    I solved it a bit different way that is without this sum trick (I was not aware of actual solution) but it actually worked for all the test cases in leet code. At test case 50 it throws time limit Exceeded error but I included the same case and run it alone it worked.🤣
    class Solution:
    def maxFrequency(self, nums, k):
    length = len(nums)
    count = 1
    max_frequency = None
    nums.sort()
    if length == 1:
    return 1
    while count k:
    break
    i = i + 1
    count = similarCount + i
    return count
    I know this is not a good solution at all. But is it ok to start the preparation for the google interview? @NeetCode

  • @VarunSharma-xd8xd
    @VarunSharma-xd8xd 9 หลายเดือนก่อน

    class Solution {
    public int maxFrequency(int[] nums, int k) {
    int total = 0;
    int L = 0;
    int R = 0;
    int res = 0;
    Arrays.sort(nums);
    while (R < nums.length) {
    total += nums[R];
    while (nums[R] * (R - L + 1) > total + k) { // Corrected condition
    total -= nums[L];
    L++;
    }
    res = Math.max(res, R - L + 1);
    R++;
    }
    return res;
    }
    } why this code failing at 71/73 test case

    • @prapti2385
      @prapti2385 8 หลายเดือนก่อน

      consider the total variable as long

  • @AnandKumar-kz3ls
    @AnandKumar-kz3ls 2 ปีที่แล้ว +1

    c++ solution if anyone stuck with integer overflow runtime error in test cases class Solution {
    public:
    int maxFrequency(vector& nums, int k) {

    sort(nums.begin(),nums.end());

    int l=0;
    int r=0;
    long long curr_sum=0;
    int max_elements=-1;

    while(r

    • @krish4659
      @krish4659 7 หลายเดือนก่อน

      myan thank you

  • @himanshurathore9816
    @himanshurathore9816 ปีที่แล้ว +1

    at last one testcase failed and only one is remaining bro
    help it out!!!!
    testcase no 70

  • @saipramod41
    @saipramod41 3 ปีที่แล้ว +2

    Awesome explanation. Can you please do text justification leetcode #68 ?

    • @ritwik121
      @ritwik121 2 ปีที่แล้ว +1

      @neetcode can we have a video on text justification ?

  • @amandubey5287
    @amandubey5287 2 ปีที่แล้ว

    Hi neetcode. I just wanted to say thank you for all these videos. However I have a leetcode hard problem in sliding window of constant length i guess. Question name " Substring with concatenation of all words". this question has been troubling me for a while now. Can you please make a video on this. Thanks

  • @AryanChaudhary-b3k
    @AryanChaudhary-b3k หลายเดือนก่อน

    I feel dumb. I could have never come up with this solution on my own.

  • @irvinge4641
    @irvinge4641 ปีที่แล้ว

    oh, because r goes to every element being the most frequent candidate

  • @atharvakulkarni3007
    @atharvakulkarni3007 3 ปีที่แล้ว

    Best Explanation No cap

  • @irvinge4641
    @irvinge4641 ปีที่แล้ว

    when you got in google, did you ace all questions in the interview with no mistakes?

  • @ranjankumarsingh4601
    @ranjankumarsingh4601 3 หลายเดือนก่อน

    Good explanation

  • @hugenerretho9151
    @hugenerretho9151 2 ปีที่แล้ว

    if u can come up w/ this on fly, u r the god even pope cant code like this

  • @chaitanyakumar8683
    @chaitanyakumar8683 2 ปีที่แล้ว

    Heyy
    Can you please tell us how to come up with these kind of formulas

  • @Cpp_For_Life
    @Cpp_For_Life 8 หลายเดือนก่อน

    Thanks man ❤❤❤

  • @_GOUTHAM
    @_GOUTHAM 3 ปีที่แล้ว

    excellent idea man

  • @shashankshekhar8186
    @shashankshekhar8186 2 ปีที่แล้ว

    best explanation!!

  • @hanyo3629
    @hanyo3629 ปีที่แล้ว +1

    Does anyone know why I'm failing the 70th test case when I'm doing this in Java?

    • @diyangli9399
      @diyangli9399 ปีที่แล้ว

      same here

    • @shivangb237
      @shivangb237 ปีที่แล้ว +2

      just convert the total to "long" instead of "int"

  • @ndas9970
    @ndas9970 5 หลายเดือนก่อน

    The answer of the example shown is wrong, the output should be 4 not 2 (frequency).but the code works fine.

  • @tanknandanijagdishbhai9272
    @tanknandanijagdishbhai9272 ปีที่แล้ว

    nice explanation..!

  • @kirtimanmishra8097
    @kirtimanmishra8097 3 ปีที่แล้ว

    awesome solution...

  • @TIENTI0000
    @TIENTI0000 3 ปีที่แล้ว +1

    thanks

  • @adityakrishnajaiswal8663
    @adityakrishnajaiswal8663 6 หลายเดือนก่อน

    res=max (res,r-l+1); why this required?

  • @gyandeepdigra8461
    @gyandeepdigra8461 ปีที่แล้ว

    for [1,1,1] k = 2 , your solution will give answer 3 , but it should be 2 . Am i wrong somewhere >?

    • @roshninagendra1264
      @roshninagendra1264 ปีที่แล้ว +1

      uh yeah...they're all the same number...so max freq is 3

    • @samk64
      @samk64 ปีที่แล้ว

      the prompt says "at most k operations", i.e. up to k operations. that means you can choose to do no operations if that gives you the max possible frequency.

  • @PalakKalsi
    @PalakKalsi 7 หลายเดือนก่อน

    Superb!

  • @awalkingnosebleed
    @awalkingnosebleed 4 หลายเดือนก่อน

    how to solve this question using hashing?

  • @verma_jay
    @verma_jay ปีที่แล้ว

    Thank you

  • @ameynaik1755
    @ameynaik1755 3 ปีที่แล้ว +1

    can you please solve this problem. Thanks!
    636. Exclusive Time of Functions

  • @rajsuriyang3427
    @rajsuriyang3427 ปีที่แล้ว

    I don't know why we are multiplying with window length?
    PS: I watched this video on repeat for an hour to understand it.

    • @roshninagendra1264
      @roshninagendra1264 ปีที่แล้ว +1

      because that would give us the total supposing all the elements of that window are that number. this has to be equal to sum + moves. thus expand, as long as product is greater than sum.

  • @rohansodha9555
    @rohansodha9555 3 ปีที่แล้ว

    Thanks a lot :)

  • @MrEdgoll
    @MrEdgoll 3 ปีที่แล้ว

    many thanks!

  • @yassineacherkouk
    @yassineacherkouk ปีที่แล้ว

    I came up whit all the algorithm except the sorting part.

  • @syedhabeebuddin101
    @syedhabeebuddin101 3 ปีที่แล้ว

    Thanks!

  • @saipraneeth2395
    @saipraneeth2395 5 หลายเดือนก่อน

    thanks alot man

  • @mitswadas
    @mitswadas 6 หลายเดือนก่อน

    Just amazing

  • @jatinbhatoya8420
    @jatinbhatoya8420 3 ปีที่แล้ว

    you are too good

  • @thesounds1676
    @thesounds1676 หลายเดือนก่อน

    how did the people actually come up with this solution :(

  • @parthbhatia341
    @parthbhatia341 9 หลายเดือนก่อน

    This is definitely not a medium

  • @vecstudio
    @vecstudio 3 ปีที่แล้ว

    awesome

  • @pisanghangus2
    @pisanghangus2 3 ปีที่แล้ว

    EUREKA!

  • @hetjayeshbhaipatel1075
    @hetjayeshbhaipatel1075 5 หลายเดือนก่อน

    wowwwwww

  • @pratikgehlot1973
    @pratikgehlot1973 2 ปีที่แล้ว

    ahh haa moment

  • @ManavChauhan-ze2bi
    @ManavChauhan-ze2bi 6 หลายเดือนก่อน

    Alright But I don't understand what its say 3 4 5 6 7 and k = 6. The above code fails on it.
    Edit: My bad I thought you could increment or decrement and for so long I've been butting my head on that, turns out the question is so much easier.

  • @tusharvatsa5293
    @tusharvatsa5293 3 ปีที่แล้ว

    Your videos are very helpful but your voice is irritating af.

    • @triscuit5103
      @triscuit5103 2 ปีที่แล้ว +1

      wtf are you talking about? First of all, what a pointless comment, you are clearly an insecure moron, especially when it comes to social interactions. I feel sorry for you and hope you get better. Second of all, his voice is not the least bit irritating at all, I actually sometimes just listen to his videos as I find his way of talking very calming. And lastly, even if he had an irritating voice (which he certainly does not), learn to be thankful for these amazing videos which are available for all of us for free.

  • @andreytamelo1183
    @andreytamelo1183 2 ปีที่แล้ว +1

    Thanks!