Bs-22. K-th element of two sorted arrays | Binary Search Approach

  Рет қаралды 100,741

take U forward

take U forward

Күн бұрын

Пікірлер: 126
@sujalgupta6100
@sujalgupta6100 8 ай бұрын
It was all good until the gas stations problem arrived. From that problem, there is always something weird logic everytime in hard problems. I feel a rewatch is required.
@codewithcode2864
@codewithcode2864 7 ай бұрын
very true brother the whole confidence goes off
@Satyendra_Prakash17
@Satyendra_Prakash17 7 ай бұрын
glad someone said
@soumiyamuthuraj3516
@soumiyamuthuraj3516 6 ай бұрын
Soo true
@priyanshshukla450
@priyanshshukla450 6 ай бұрын
Facts, everything was going good till that gas station problem 😭
@RAHUL-gl3ye
@RAHUL-gl3ye 6 ай бұрын
But the gas station problem requires premium on leetcode right? 👀
@Dontpushyour_luck
@Dontpushyour_luck Жыл бұрын
did it by my own after learning median of two sorted arrays concept from you! thank you
@atharvakj
@atharvakj 7 ай бұрын
which one ?
@MR._NEEN
@MR._NEEN Жыл бұрын
I AM IMPROVING MYSELF IN PROBLEM SOLVING DAY BY DAY BECAUSE OF YOU. I AM SLAVE TO YOUR PLAYLIST
@bruvhellnah
@bruvhellnah 2 ай бұрын
what the actual f lmao
@FusionArcs
@FusionArcs Жыл бұрын
finally, the mystery of why low and high needs to be corrected for this solution? Let's take an example, m = 3, n = 10, k = 12 If we keep low = 0, and high = 3 then mid1 = 1; low = 0 means we don't pick any element from the first array, and now the remaining elements need to be picked from the second array. mid2 = (k - mid1) = 12 - 1 = 11 ???? but there are only 10 elements in the second array Hence we can't start our search when we pick no elements from the first array. So our low must be max(k - n, 0) [no of elements at least need to pick for 1st array] Similarly, for high, we have to reduce the search space such that it can handle low K values. Note: this issue doesn't occur in the median problem because we guaranteed to split the search space in half every time.
@aryansoni8819
@aryansoni8819 8 ай бұрын
bro when mid1=1 then you pick one element from first array correction rest are correct
@JIGARSINGTHAKOR-yy6qp
@JIGARSINGTHAKOR-yy6qp 6 ай бұрын
can you furthur explain why it does not happens in median.?
@anandpandey918
@anandpandey918 6 ай бұрын
//Bruteforce Approach class Solution { public long kthElement(int arr1[], int arr2[], int m, int n, int k) { int[] merged = mergeTwoSortedArrayIntoThirdSortedArray(arr1, m, arr2, n); return merged[k - 1]; } private int[] mergeTwoSortedArrayIntoThirdSortedArray(int[] arr1, int m, int[] arr2, int n) { int[] merged = new int[m + n]; int i = 0, j = 0, k = 0; while (i < m && j < n) { if (arr1[i]
@vamsikrishnagannamaneni912
@vamsikrishnagannamaneni912 2 ай бұрын
In median it will work because we never ask to pick more than the largest array have, because of the formula (n1+n2+1)//2
@parthrastogi572
@parthrastogi572 Жыл бұрын
Just search for this question's solution and here comes the video just 4 hours ago!! Thanks for your help!
@nandhinik04
@nandhinik04 28 күн бұрын
For those who didn't understand consider the example: n1=4, n2=6, k=8 if we assume low=0 and high=n1 it means there is a possibility of taking 0 elements from n1 arr and remaining elements from n2 arr (which has only 6 elements but we need 8 elements at left so its mandatory to consider atleast 2 elements from left arr) so low = max(0, k-n2) and for high consider the scenario n1=4, n2=6, k=2 where need to have only 2 elements at left so should consider atmost 2 elements from n1 arr so high = min(k, n1)
@aamir4684
@aamir4684 8 күн бұрын
brother you are from which year?
@nandhinik04
@nandhinik04 7 күн бұрын
@aamir4684 why are u asking for?
@sayantanmanna1360
@sayantanmanna1360 Жыл бұрын
Hey @takeUforward , there's a small mistake in the optimal solution posted on the website. It says `int low = max(0,k-m), high = min(k,n) ; ` where `m` and `n` are the length of the first and second array respectively. According to this lecture, it should be `int low = max(0,k-n), high = min(k,m) ; `
@cinime
@cinime Жыл бұрын
Understood! Super fantastic explanation as always, thank you very very much for your effort!!
@sumitbhardwaz
@sumitbhardwaz 6 сағат бұрын
Amazing. I came up picking high as K but picking up low as max of k - n2, 0 is amazing. Well I thought I needed a whole lot more of dry run.. that's shows we need to do dry run on every value we pick. In every scenario only when we would able to come up on such thing
@ArpanChakraborty-do6yz
@ArpanChakraborty-do6yz 11 ай бұрын
Awesome 😎👍🏻 11:41
@stith_pragya
@stith_pragya 8 ай бұрын
UNDERSTOOD......Thank You So Much for this wonderful video.........🙏🏻🙏🏻🙏🏻🙏🏻🙏🏻🙏🏻
@sidharthsharma341
@sidharthsharma341 Жыл бұрын
Bhaiya which topic will come next ?.....what are upcoming plans
@guttulavybhav1030
@guttulavybhav1030 6 ай бұрын
bro there is a correction if for suppose m=5 and n=6 and k=7 then if we take up all the 6 elements from arr2 then we need atleast one element to be taken from arr1. so low should be 1. so formula will be max(0,k-n) i.e 7-6=1 so low should be 1 in order to select k elements from left.
@lokeshnegi5051
@lokeshnegi5051 5 ай бұрын
I think some questions are made to skip and this is also one of those inlcuding medain of sorted arrays
@redBaron_80
@redBaron_80 3 ай бұрын
why was the low and high check was not needed in the median problem?
@Pw_Unfiltered
@Pw_Unfiltered 11 күн бұрын
start 05:01
@taneyasoni
@taneyasoni Жыл бұрын
please post the link to the prerequisite video.
@soumy_jain
@soumy_jain Ай бұрын
Let n1 and n2 be the sizes of the smaller and bigger arrays, respectively, and let count1 be the number of elements taken from the smaller array, with count2 being the number of elements taken from the bigger array. In the median problem, the condition count2 = k - count1 will never result in a negative value because k = (n1 + n2) / 2. Since count1 is taken from the smaller array, it can be at most (n1 + n2) / 2. Therefore, count2 = k - count1 (where count1
@SiddhiLandage
@SiddhiLandage Ай бұрын
hello for low we take min( 0 , k -n1 ) where n1 is the smaller array size i.e in above example which you have given { array1 size is 6 and array 2 size = 5 } you said low = 2 means we will defintely take 2 elments from array which has size 6 but we apply binary search on the smaller array so it means that we must take 2 elments from the smaller array is it right?
@vivekverma4012
@vivekverma4012 Жыл бұрын
But sir, ultimately low will reach max(k-n2,0) and high will reach min(k,n1) during the execution of while loop and will reach the desired answer. Then why not leave low=0 and high=n1 as it is?? May be it takes somewhat more time but as u say it's giving wrong output.
@samirkeshwani9409
@samirkeshwani9409 Жыл бұрын
if you pick n1 elements from a1 array (suppoes n1>k)then atlast when you find suitable configuration then in ans max(l1,l2) gives wrong answer as you picked an element which is after k so i think this might be the reson for high to be restritcted i am not sure though
@FusionArcs
@FusionArcs Жыл бұрын
Let's take an example, m = 3, n = 10, k = 12 If we keep low = 0, and high = 3 then mid1 = 1; low = 0 means we don't pick any element from the first array, and now the remaining elements need to be picked from the second array. mid2 = (k - mid1) = 12 - 1 = 11 ???? but there are only 10 elements in the second array Hence we can't start our search when we pick no elements from the first array. So our low must be max(k - n, 0) [no of elements at least need to pick for 1st array] Similarly, for high, we have to reduce the search space such that it can handle low K values. Note: this issue doesn't occur in the median problem because we guaranteed to split the search space in half every time.
@vivekverma4012
@vivekverma4012 Жыл бұрын
@@FusionArcs understood, thanks😀
@anandpandey918
@anandpandey918 6 ай бұрын
//Bruteforce Approach class Solution { public long kthElement(int arr1[], int arr2[], int m, int n, int k) { int[] merged = mergeTwoSortedArrayIntoThirdSortedArray(arr1, m, arr2, n); return merged[k - 1]; } private int[] mergeTwoSortedArrayIntoThirdSortedArray(int[] arr1, int m, int[] arr2, int n) { int[] merged = new int[m + n]; int i = 0, j = 0, k = 0; while (i < m && j < n) { if (arr1[i]
@akilsabir1088
@akilsabir1088 28 күн бұрын
what's the use of int n in BS approach.
@urstrulyjatin
@urstrulyjatin 2 ай бұрын
Thanks stiver, love you. See you at google soon.
@SYCOA12CHAITANYAASOLE
@SYCOA12CHAITANYAASOLE 7 ай бұрын
Understood !! 😍😍
@YourCodeVerse
@YourCodeVerse Жыл бұрын
Understood✅🔥🔥
@mehedihasansabbir7886
@mehedihasansabbir7886 Жыл бұрын
Great explanation
@joelpires1342
@joelpires1342 8 ай бұрын
Why marked as done, if it didn't work?
@NazeerBashaShaik
@NazeerBashaShaik 9 ай бұрын
Understood, thank you.
@sambhavraghav7360
@sambhavraghav7360 2 ай бұрын
why these low and high conditions were not in median problem?
@kurma.4932
@kurma.4932 Ай бұрын
In the median problem, when we merge two sorted arrays, we are splitting the elements of the array into two halves Now, if we split the merged array in half, the left half will always contain n/2 elements, right? For example, suppose there are 10 elements in total, and n/2 equals 5. So, the left half would have 5 elements. Now, the purpose of the low and high pointers is to help you figure out how many elements you can take from each array. If high is n1 (where n1 is the size of the first array), it means the maximum number of elements you can take from the first array is n1-which simply means you can take all the elements from the first array. Since n/2 is 5 elements (last video), it means the two halves of the merged array should have an equal number of elements ( 5 elements each). Now we have a left variable( n / 2) as well, which goes as mid2 = left - mid1, so = left basically makes sure that if 2 elements are taken from arr1, remaining 3 will be taken from arr2 So left simply handles everything Now, let's discuss why we check low and high here: In the case of finding the median, the left side is not necessarily the exact middle of the total number of elements (n1 + n2), because of the introduction of k. as here left = k, This means that the left side won't always have an equal number of elements from both arrays. There are cases where we must take at least one or two elements from the first array. So, starting with low = 0 may not always work.(suppose we must need minimum 1 element from one array but low 0 fails here) Similarly, if we take high = n1 (for instance, if n1 = 5) but we only need 2 elements because k = 2, there’s no point in taking all n1 elements from the first array. This is why adjusting low and high is necessary.
@Slayer-070
@Slayer-070 7 ай бұрын
read solution in the sheet for clear explanation.
@kunal5077
@kunal5077 7 ай бұрын
showing TLE on code 360 please tell how to evaluate.
@amitranjan6998
@amitranjan6998 Жыл бұрын
@Striver Bhaiya, For K=7 , why we can't peak from arr1 all the 6 element and 1 from array2 . Just confuse with low , why it's max(k-n2,0). If any one also help, will great for me.
@vivekverma4012
@vivekverma4012 Жыл бұрын
since, low=max(k-n2,0) so it indicates we have to select atleast these many elements from arr1.
@amitranjan6998
@amitranjan6998 Жыл бұрын
@@vivekverma4012 that I got it, my question why not to pick from arr1 first rather taking from arr2 first
@tapansonak1431
@tapansonak1431 Жыл бұрын
Watch the previous video, median of two sorted arrays, in that video he explained that we always pick elements from the smaller array, as it will reduce the time complexity. In the given example arr1[] has 6 elements and arr2[] has 5, so picked elements from arr2[].
@FusionArcs
@FusionArcs Жыл бұрын
Let's take an example, m = 3, n = 10, k = 12 If we keep low = 0, and high = 3 then mid1 = 1; low = 0 means we don't pick any element from the first array, and now the remaining elements need to be picked from the second array. mid2 = (k - mid1) = 12 - 1 = 11 ???? but there are only 10 elements in the second array Hence we can't start our search when we pick no elements from the first array. So our low must be max(k - n, 0) [no of elements at least need to pick for 1st array] Similarly, for high, we have to reduce the search space such that it can handle low K values. Note: this issue doesn't occur in the median problem because we guaranteed to split the search space in half every time.
@anandpandey918
@anandpandey918 6 ай бұрын
//Bruteforce Approach class Solution { public long kthElement(int arr1[], int arr2[], int m, int n, int k) { int[] merged = mergeTwoSortedArrayIntoThirdSortedArray(arr1, m, arr2, n); return merged[k - 1]; } private int[] mergeTwoSortedArrayIntoThirdSortedArray(int[] arr1, int m, int[] arr2, int n) { int[] merged = new int[m + n]; int i = 0, j = 0, k = 0; while (i < m && j < n) { if (arr1[i]
@devarapallivamsi7064
@devarapallivamsi7064 11 ай бұрын
My code that's a bit different from what is explained in the video: Please do a dry run. you will get it. (Python) def kThElement(arr1, arr2, k): n1 = len(arr1) n2 = len(arr2) if n1 > n2: return kThElement(arr2,arr1,k) low = 0 high = n1 while low k: high = mid1 - 1 continue if mid2 > n2: low = mid1 + 1 continue l1 = float('-inf') r1 = float('inf') l2 = float('-inf') r2 = float('inf') if mid1 >= 1: l1 = arr1[mid1 - 1] if mid1 < n1: r1 = arr1[mid1] if mid2 >= 1: l2 = arr2[(k - mid1) - 1] if mid2 < n2: r2 = arr2[(k - mid1)] if l1
@lohithreddym4
@lohithreddym4 7 ай бұрын
it's the same
@surbhirathore._
@surbhirathore._ 7 ай бұрын
Where are the notes?
@Ungan_Tamilan
@Ungan_Tamilan Жыл бұрын
Forever strivers
@shamanthhegde2820
@shamanthhegde2820 24 күн бұрын
class Solution: def findMedianSortedArrays(self, nums1: List[int], nums2: List[int]) -> float: n1 = len(nums1) n2 = len(nums2) if(n2 < n1): return self.findMedianSortedArrays(nums2, nums1) n = n1 + n2 if(n%2 != 0): isEven = False left = (n)//2 + n%2 low = 0 high = n1 l1 = -1 l2 = -1 r1 = -1 r2 = -1 while(low
@saikumargatla4706
@saikumargatla4706 Жыл бұрын
To be precise low=max(0, k-sizeoflargerarray)
@allaboinadivakar1976
@allaboinadivakar1976 Жыл бұрын
we always consider n2 as larger array bro
@prikshit_sharma4071
@prikshit_sharma4071 Жыл бұрын
Thank you 😊❤
@shubha_jagadeesh
@shubha_jagadeesh 2 ай бұрын
understood😍
@devarapallivamsi7064
@devarapallivamsi7064 11 ай бұрын
Understood!
@shashwattopre9672
@shashwattopre9672 Жыл бұрын
Why high=max(k,n1)? I am unable to understand.
@nihalsingh6233
@nihalsingh6233 Жыл бұрын
High = min(N1, k ) It is because if we want just 2 elements in left hand side and N1 is 5 then why we need increase our search space upto 5, just simply shrink it to 2. Because we will be need only 2 elements in left hand side. Hope it helps !!!
@anandpandey918
@anandpandey918 6 ай бұрын
//Bruteforce Approach class Solution { public long kthElement(int arr1[], int arr2[], int m, int n, int k) { int[] merged = mergeTwoSortedArrayIntoThirdSortedArray(arr1, m, arr2, n); return merged[k - 1]; } private int[] mergeTwoSortedArrayIntoThirdSortedArray(int[] arr1, int m, int[] arr2, int n) { int[] merged = new int[m + n]; int i = 0, j = 0, k = 0; while (i < m && j < n) { if (arr1[i]
@per.seus._
@per.seus._ Жыл бұрын
UNDERSTOOD
@anshsaxena7297
@anshsaxena7297 4 ай бұрын
UnderStood
@ekanshgupta2930
@ekanshgupta2930 Жыл бұрын
can anyone tell why does this code not pass on gfg I have been trying to do it for 2hrs now and am unable to find the error
@GeorgianHarshAnand
@GeorgianHarshAnand Жыл бұрын
if(n > m) return this.kthElement(B , A , m , n , k) let i = Math.max( 0 , k-m) , j = Math.min(k , n) while(i = 0) l1 = A[mid1-1] if( mid2 < m) r2 = B[mid2] if(mid2 - 1 >= 0 ) l2 = B[mid2 - 1] if(l1
@jewelchakraborty9717
@jewelchakraborty9717 10 ай бұрын
class Solution { public long kthElement( int a1[], int a2[], int n1, int n2, int k) { if(n1 > n2) return kthElement(a2, a1, n2, n1, k); int low = Math.max(0, k - n2); int high = Math.min(k, n1); while(low 0) l1 = a1[mid1 - 1]; if(mid2 > 0) l2 = a2[mid2 - 1]; if(l2 > r1) low = mid1 + 1; else if(l1
@Learnprogramming-q7f
@Learnprogramming-q7f 11 ай бұрын
Thank you Bhaiya
@BOSS55
@BOSS55 Жыл бұрын
thansks
@oyeshxrme
@oyeshxrme 5 ай бұрын
understood bhaiya
@DhananjayKumar-bd2jg
@DhananjayKumar-bd2jg Жыл бұрын
8:25
@dogwoofwoof8154
@dogwoofwoof8154 Жыл бұрын
easy 120 points :)
@arpitbhavsar6020
@arpitbhavsar6020 Жыл бұрын
Understood
@tusharsingh1257
@tusharsingh1257 8 ай бұрын
Completed 29th May 2024
@arihantjammar8888
@arihantjammar8888 Жыл бұрын
understood
@pratyakshhhhhhhhhhhhhhhhhhhhh
@pratyakshhhhhhhhhhhhhhhhhhhhh Жыл бұрын
🎉🎉❤
@allaboinadivakar1976
@allaboinadivakar1976 Жыл бұрын
@girikgarg8
@girikgarg8 Жыл бұрын
Done
@apoorva5961
@apoorva5961 Ай бұрын
😇
@raghavsapra2792
@raghavsapra2792 Жыл бұрын
3rd comment love u striver...
@cenacr007
@cenacr007 Жыл бұрын
us
@codderrrr606
@codderrrr606 Жыл бұрын
kachwa bhai har jagah aa jata h
@codderrrr606
@codderrrr606 Жыл бұрын
striver bhai kachwa bhai ko rok lo
@dewanandkumar8589
@dewanandkumar8589 9 ай бұрын
Understood!
@nihalsingh6233
@nihalsingh6233 Жыл бұрын
Understood
@KAMLESHSINGH-vr3bl
@KAMLESHSINGH-vr3bl Жыл бұрын
understood
@shruti-m4e
@shruti-m4e 6 сағат бұрын
us
@rajatshukla2605
@rajatshukla2605 3 ай бұрын
Understood!
@PrinceTripathi-j7u
@PrinceTripathi-j7u Жыл бұрын
Understood
@culeforever5408
@culeforever5408 Жыл бұрын
understood
@rakeshbasak6842
@rakeshbasak6842 Ай бұрын
Understood!
@salendraraviteja8472
@salendraraviteja8472 Жыл бұрын
Understood
@abhinanda7049
@abhinanda7049 Жыл бұрын
understood
@NARUTOUZUMAKI-bk4nx
@NARUTOUZUMAKI-bk4nx 11 ай бұрын
Understood
@udatyadeb101
@udatyadeb101 Жыл бұрын
understood
@LearnerForever123
@LearnerForever123 9 ай бұрын
Understood
@chiragbansod8252
@chiragbansod8252 10 ай бұрын
understood
@aryankumar3018
@aryankumar3018 6 ай бұрын
Understood
@Rohan_K_Das_22BCE164
@Rohan_K_Das_22BCE164 6 ай бұрын
Brother can you explain why the changes for low and high stuffs were used here and not in the median qn, am a bit confused in that ...
@hardikpatel352
@hardikpatel352 8 ай бұрын
understood
@krishkumar491
@krishkumar491 5 ай бұрын
Understood
@ashishpradhan6250
@ashishpradhan6250 7 ай бұрын
understood
@SitaRam-m1i
@SitaRam-m1i 3 ай бұрын
Understood
@Harsh-jc2bz
@Harsh-jc2bz 5 ай бұрын
understood
@KrishMewari-y3k
@KrishMewari-y3k 6 күн бұрын
Understood
@anmolsaini2783
@anmolsaini2783 5 ай бұрын
understood
@himasreedadam7670
@himasreedadam7670 28 күн бұрын
understood
@divyakumardivyanshu4279
@divyakumardivyanshu4279 5 күн бұрын
understood
BS 23. Row with maximum number of 1s | Binary Search on 2D Arrays
10:18
UFC 310 : Рахмонов VS Мачадо Гэрри
05:00
Setanta Sports UFC
Рет қаралды 1,2 МЛН
REAL or FAKE? #beatbox #tiktok
01:03
BeatboxJCOP
Рет қаралды 18 МЛН
ML Was Hard Until I Learned These 5 Secrets!
13:11
Boris Meinardus
Рет қаралды 360 М.
NVIDIA CEO Jensen Huang's Vision for Your Future
1:03:03
Cleo Abram
Рет қаралды 97 М.
I made Tetris in C, this is what I learned
15:15
Austin Larsen
Рет қаралды 30 М.
BS-9. Find Peak Element
32:53
take U forward
Рет қаралды 224 М.
BS-24. Search in a 2D Matrix - I | Binary Search of 2D
15:42
take U forward
Рет қаралды 132 М.
Fast Inverse Square Root - A Quake III Algorithm
20:08
Nemean
Рет қаралды 5 МЛН
I gave 127 interviews. Top 5 Algorithms they asked me.
8:36
Sahil & Sarra
Рет қаралды 690 М.
UFC 310 : Рахмонов VS Мачадо Гэрри
05:00
Setanta Sports UFC
Рет қаралды 1,2 МЛН