The first sentence is awesome: I'm sure you didn't understand anything from the problem statement!
@techdose4u4 жыл бұрын
🤣
@ibrahimshaikh36424 жыл бұрын
😄
@NewMovieTrailersTransformed4 жыл бұрын
I liked it too because i really didn't understood anything about the problem :P
@AG-zc2jt3 жыл бұрын
🤣
@MinhNguyen-lz1pg2 жыл бұрын
Yep same here, glad that im not the only one lol
@misoren96453 жыл бұрын
Hi for anyone wondering why we use upper_bound instead of lower_bound, I thought about it and here is the explanation: 1) lower bound returns the first element (in the range) "not less than" (i.e. greater or equal), upper bound returns the first element greater than the value to search. 2) The value to search is rand()%sum and this returns a number from (0 to sum - 1). Particular cases: a) so say you search for the value (sum - 1) [last possible value in rand()%sum] you should return the last index as well, which is why you would be searching for sum, which is greater than sum - 1, so you use upper bound. For instance if last value of the weights/array is 1, lower_bound would give the index before the last one, which is equal to sum - 1, which would be wrong. b) Say, the first element of the cumulative sum is x (S[0] = x), then numbers from (0... x- 1) should map to first index (0 / S[0]) (since this fills a "bucket" of length "x"), so if you search for value x you should map to the second index, so using lower_bound of x would give you 0, which is wrong. So you use upper_bound. For example, say array is [1,2,3], sum is [1,3,6] if you search for value 1, you should not return 0, which is what lower bound gives, since they are equal, you should return 1, because the number 0 (in the line) is mapping to 1, so the bucket of size 1 is already allocated. For the general case: each interval of numbers map until S[x] - 1, so if you search for S[x], using lower_bound gives you x, but x maps until S[x] - 1 and not S[x], so you need the first greater value, which upper bound gives. Therefore you use upper_bound. This is also why, you can use lower_bound if you add + 1 to the value searching (rand() % sum + 1), in that case, first index will map from (1... to S[0]), so searching with lower_bound S[0] should give you 0, which is correct and similar for the general case.
@ShubhamMahawar_Dancer_Actor4 жыл бұрын
worst explanation by leetcode in their problem statement ,but you nailed it.
@techdose4u4 жыл бұрын
😅
@sneha_20054 жыл бұрын
Thanks for this video. I was trying so hard to understand the question from the discussion section and everyone was using this cumulative array and I couldn't understand how it is helping. Now I am getting it finally!
@techdose4u4 жыл бұрын
The problem was not at all explained. It was a very good problem but only if the problem statement was better 😅
@ShreyanGoswami4 жыл бұрын
I think this is the most interesting problem leetcode has given in their monthly coding challenge. Thanks for the explanation.
@techdose4u4 жыл бұрын
I agree with you. But they ruined the problem using very poor problem statement.
@avaz79392 жыл бұрын
I love your opening of "I'm pretty sure you didn't get anything from this problem statement" :D Great explanation
@roshankharke37254 жыл бұрын
Sir, your mic quality is so good everything you explain is pretty clear and I can listen to you all day :P
@techdose4u4 жыл бұрын
🤣hahaha Nice
@NikhilKumar-oy7mx4 жыл бұрын
yaha thodi koi number de raha h. aadat jayegi nhi tumhari :) (:
@niranjanhegde15354 жыл бұрын
Wow! Was waiting for this video. I had difficulty in understanding the question
@techdose4u4 жыл бұрын
:)
@100bands4 жыл бұрын
Great explanation as always. One subtle thing I think you should have mentioned is that the expected leetcode answer is likely to be different from your actual answer but it doesn't mean that your answer is wrong. This wasn't obvious to me at first.
@techdose4u4 жыл бұрын
Actually these type of random distribution type question depends on your percentage accuracy. Question setter knows the distribution of rand fn (which is not completely random). We are not using changing seed as well. That's how these questions work.
@sameergirkar4 жыл бұрын
Quick Clear and Complete explanation of the problem as well as the solution. 👍🏻 Thank for the explanations.
@techdose4u4 жыл бұрын
Welcome :)
@bhumikabhatia34164 жыл бұрын
Is there a reason why we can't use lower bound? All the test cases did not pass if I used lower bound. >= will be lower bound so if our random number is 3 it should fall in the second bucket right so what's wrong with using lower bound?
@techdose4u4 жыл бұрын
I think lower_bound gives you the floor and upper_bound gives you the ceil and we have assumed our bucket to end at cumulative sum. Each bucket is assumed to be to the left of the current element. So it's natural to use ceil and not floor.
@techdose4u4 жыл бұрын
Lower and Upper bound both are failing for this problem now. So it is required to implement our own binary search.
@misoren96453 жыл бұрын
@@techdose4u lower_bound, upper_bound and the solution implemented has nothing to do with ceil and floor. Ceil and floor are for decimal (with decimal part) numbers. Here the weights are integers and the cumulative sum therefore is also an integer, so searching the number and the modulus operation is also an integer, so there is no ceil/floor operation here. Rather lower_bound is for not less than (greater or equal) comparison while upper_bound is for greater comparison.
@yitingg79423 жыл бұрын
Wow Great explanation. Can't believe you can do it this way.
@techdose4u3 жыл бұрын
Thanks :)
@NikhilKumar-oy7mx4 жыл бұрын
this can also be used for probability array like in 1st example probability were (1/6, 2/6, 3/6) so create a vector and store 1 once, 2 twice and 3 thrice. and when you generate rand() from this the purpose will be fulfilled. Please let me if this lacks in any manner than what's shown in video.
@techdose4u4 жыл бұрын
This cannot be used. Your weight range from 1 to 1e5. You cannot make a line by counting each number. This is the same concept as perfect subarray from Google kickstart round C question 3. You should have seen that. You idea can work for very small numbers and will consume a lot of extra space.
@neelalexpaul3 жыл бұрын
Great explanation. I would suggest using lower_bound over upper_bound to make the concept clear. Something like the following: int random = (rand() % maxVal) + 1; return (lower_bound(prefixSum.begin(), prefixSum.end(), random) - prefixSum.begin());
@divyashahi93643 жыл бұрын
why haven't u used lower_bound it would have been more appropriate, but using lower_bound gives wrong ans from larger test input may you please explain that, BTW, really nice explanation.
@techdose4u3 жыл бұрын
I will check.
@awsomeoproductions44 жыл бұрын
Amazing video! What microphone do you use?
@techdose4u4 жыл бұрын
Boya
@jivanmainali17423 ай бұрын
it would be interesting to know how test cases are validating output
@subhamkumarmishra96104 жыл бұрын
Late upload bro. I had been waiting for your video to pop up. Your explanations are pretty amazing .
@techdose4u4 жыл бұрын
Office work will make videos late 😅
@amarnaath56734 жыл бұрын
TECH DOSE I guess youre Surely working in FANG wow what a talent Man✨
@subhamkumarmishra96104 жыл бұрын
@@amarnaath5673 HAHA ! yes you are right.
@birudaya99644 жыл бұрын
same here. :P
@mehular0ra4 жыл бұрын
explained really well sir!
@techdose4u4 жыл бұрын
Thanks :)
@The85souvikdas4 жыл бұрын
Thank you for the explanation...problem was very unclear.
@techdose4u4 жыл бұрын
Yea correct :)
@sreejiths27354 жыл бұрын
Great explanation, but how are we sure that rand function always produces the result in the way we wanted, if it's completely random, then it can stick to a single element or two also right.
@techdose4u4 жыл бұрын
Nope. Rand sequence depends on seed value. Rand is based on algorithms which is not random. If you give same input then you will get same output. To make it look random, we generally use seed value as a previous value using which subsequent random numbers are generated. Generally current time is used as a seed in rand() and so it won't ever stick to one value. If you compile and generate random nos then you will get the same sequence each time if you don't explicitly use changed seed for each compilation. The problem setter doesn't expect you to do this. Thats how it predicts the rand generation graph. It has a typical distribution curve. Search. Nothing is completely random.
@sreejiths27354 жыл бұрын
@@techdose4u Wow, this cleared my doubts, thank you so much for the detailed explanation sir, you are doing an extremely awesome work.
@techdose4u4 жыл бұрын
Thanks :)
@NikhilKumar-oy7mx4 жыл бұрын
I am not sure how the ans is checked as at the end we are generating random and picking based on probability so even though the probability might be less for some element but still it can be picked.
@techdose4u4 жыл бұрын
Answer is checked correctly because they the distribution of rand(). So a certain percentage of error can be allowed and if you get lower error then you pass because you must have followed correct process. Rand() is not random. I have already explained this to one guy in comment. It all depends on the seed you use. Same seed or no seed will yield same answer after compilation.
@gadgetguy6651 Жыл бұрын
Amazing explanation!
@srivatsanv.r11624 жыл бұрын
I was waiting for your explanation. I followed the same approach of cumulative sum and binary search. Only half of the test cases were passed but when I tried to find iterative way solution got accepted. I didn’t use any binary search utility rather I wrote it as a function. I tried to print the sum index for most of the random elements and it was fine. Not sure why it failed. Help me. Thanks Tech dose 🙏
@techdose4u4 жыл бұрын
Glad that you implemented :)
@chankwongyin74552 жыл бұрын
Well explained!
@tzuilee5882 ай бұрын
well explained, thanks
@techdose4u2 ай бұрын
welcome :)
@nagajaswanth8314 жыл бұрын
Waited for you video .......
@techdose4u4 жыл бұрын
I hope you tried your best to solve it :)
@nagajaswanth8314 жыл бұрын
@@techdose4u yes sir, I always try to complete the question before you upload your video, but I didn't understand this question..you prove that wait is worth....
@techdose4u4 жыл бұрын
Thanks :)
@markos89554 жыл бұрын
you use upper_bound . why not lower_bound()?
@techdose4u4 жыл бұрын
Don't use either. Implement your own. None of them are working now.
@abhishekgairola91664 жыл бұрын
Why do we use upper_bound and not lower_bound , and % is taken with sum and not sum+1??
@jivanmainali17423 ай бұрын
lower_bound() for when you modulo sum+1 would do the job
@evgeni-nabokov4 жыл бұрын
Understanding the problem took more time than making up the algorithm in my head. I am curious how they test nondeterministic solutions.
@TheTushar354 жыл бұрын
would like to meet you sometime! How can i contact you?
@techdose4u4 жыл бұрын
My pleasure :)
@ishakansal7784 жыл бұрын
thankyou so much sir. Sir its a request if you can share a list of all questions asked in Microsoft coding round. I am preparing for 2020 campus placements
@techdose4u4 жыл бұрын
There is no specific questions for Microsoft. Just practice as many questions as you can. No special questions are asked for it. Everyone will ask the same type of questions.
@sohinidey67114 жыл бұрын
Still now I can't understand the meaning of the question to ready the question again.. understood ur video..
@techdose4u4 жыл бұрын
It was not explained at all. How can anyone solve without understanding what to do 😅
@neelamgour55384 жыл бұрын
@@techdose4u how did you get then
@minakshikudalkar5574 жыл бұрын
Really appreciate your efforts Sir :) Thanks for the videos, very clear and easy to understand!
@techdose4u4 жыл бұрын
Thanks :)
@ajaychauhan-lu6yy4 жыл бұрын
consider the weights as 1 2 3 4 now the cumulative sums are. 1 3 6 10... suppose randomly generated number is 3...its upper bound will give index corresponding to 6 i.e 2 whereas the ans should be 1 which is given by lower bound...why is this so?? PLEASE EXPLAIN..
@techdose4u4 жыл бұрын
Both upper and lower bound are now giving wrong answers. Better to just implement binary search.
@ajaychauhan-lu6yy4 жыл бұрын
@@techdose4u so why upper bound solution got accepted???
@vaibhavgoel39154 жыл бұрын
Awesome Explanation, curious to know that as in your code you are not making any IO operation by yourself, so do using fast IO in solution constructor will effect the speed of the code
@techdose4u4 жыл бұрын
Yes. Try without it and you will understand.
@Evie-uj1en2 жыл бұрын
"I'm pretty sure you didn't get anything from this problem statement..." LMAO
@adrian147522 жыл бұрын
this might be really dumb, but where in the question does it say the weights are sorted?
@Igloo114 жыл бұрын
Always awesome explanation!!
@andyhujian4 жыл бұрын
What if the range of rand() is smaller than v.back()?
@techdose4u4 жыл бұрын
Rand_Max is atleast 32767 and it depends on implementation and our weights were were 10K if I remember correctly. So, there will be no problem. The question setter must be knowing these stuffs 😅
@pavanguntuboina89344 жыл бұрын
Sir y upper_bound y not lower_bound could u tell me plz
@techdose4u4 жыл бұрын
This you should try yourself. Forget upper and lower bound. Just remeber binary search.
@fatimajaffal98434 жыл бұрын
I just wonder why you subtract -v.begin() ?
@techdose4u4 жыл бұрын
Upper bound doesn't give integer type but difference if those 2 values will give integer. V.begin() is always first index. So subtracting it is as good as not subtracting. That is just done to change the data type to integer.
@fatimajaffal98434 жыл бұрын
@@techdose4u got it, thanks for very helpful video.
@techdose4u4 жыл бұрын
Welcome :)
@NikhilKumar-oy7mx4 жыл бұрын
@@techdose4u you can also use binary_search()
@birudaya99644 жыл бұрын
what they actually meant in the output portion, I meant how they are related to our return value. Also, how the latter pickindex arrays are filled? this question is still unbelievable
@techdose4u4 жыл бұрын
Poor problem statement but very good question if properly explained.
@ashishm88504 жыл бұрын
Thank you!
@techdose4u4 жыл бұрын
Welcome :)
@soumilkhandelwal43884 жыл бұрын
Man, the question said nothing about the question itself... lol. Thanks for explanation
@techdose4u4 жыл бұрын
Yea correct 😅
@agileprogramming74634 жыл бұрын
Wow that was a tough one!
@saurabhsomani91884 жыл бұрын
Hi Surya, I have followed your approach and have written my java code. The code is failing 1 particular test case on LeetCode. Can you please have a look at the below code and let me know your thoughts on it? ``` class Solution { int sum = 0; int[] bucket; public Solution(int[] w) { bucket = new int[w.length]; //calculate sum for(int i : w) sum += i; //Bucket array will define the range in which the random number generated should be found //The bucket array will have single values which will define the rightmost side of range //with the leftmost number denoted by it previous value. //for index 0, the previous number will be zero '0'. So the range will be 0 to w[0]. //now for the next element at index 1 the leftmost side will be bucket[0] + w[1]. int leftBoundary = 0; for(int i = 0; i < w.length; i++){ bucket[i] = leftBoundary + w[i]; leftBoundary = bucket[i]; } //For the random number to be searched and determine if it lies in which bucket, we will only //use the rightmost side of the range, i.e, the value in the bucket array. //if the random number generated is less than the righmost side of range, we choose that bucket //by returning its index. Here the index corresponds to same position in 'w' array & in //'bucket' array. } public int pickIndex() { Random rand = new Random(); int upperBound = sum + 1; //random numbers to be generated from 0 to sum int randomNumber = rand.nextInt(upperBound); //since the bucket array is a cumulative sum, it is in sorted order. So do a binary search int start = 0; int end = bucket.length - 1; while(start < end){ int mid = start + (end - start) / 2; // if(bucket[mid] == randomNumber) // return mid; // else if (bucket[mid] >= randomNumber) end = mid; else start = mid + 1; } return start; } } /** * Your Solution object will be instantiated and called as such: * Solution obj = new Solution(w); * int param_1 = obj.pickIndex(); */ ```
@saurabhsomani91884 жыл бұрын
Hi Surya, I fixed the code. The error was with the scope of 'Random' class variable. I made the variable as a global instance and used 'this' keyword for all the global/class variables.
@DeepakSingh-uf5vv6 ай бұрын
What if the array is made up of floats something like 0.76546, 2, 0.65, ....
@Anand_Jena4 жыл бұрын
hi what os are you using ?
@kumarc48533 жыл бұрын
thank you
@techdose4u3 жыл бұрын
Welcome
@--------------------------27922 жыл бұрын
rand()%sum will never choose sum we should use sum+1 it got passed in online judge because some relaxation is given for random number question.
@ashuterasoft3 жыл бұрын
you are awesome
@boyuanchang87083 жыл бұрын
I subscribed as soon as you said I'm sure you didn't understand anything from the problem statement lmfao...
@techdose4u3 жыл бұрын
😂
@simplecop1234 жыл бұрын
I cheated myself by copy pasting the solution for this problem. Because I do not want to lose the streak of coding challenge. Leetcode have so many good problems yet they go with stupid problem.
@techdose4u4 жыл бұрын
This problem was very good but sadly, poorly framed :(
@spetsnaz_24 жыл бұрын
Don't know what to say about this question 😐
@techdose4u4 жыл бұрын
🤣 Don't utter anything.
@HimanshuSingh-ob9qo4 жыл бұрын
👍
@techdose4u4 жыл бұрын
👍
@shrad66114 жыл бұрын
explanation is good but I really hate this problem
@techdose4u4 жыл бұрын
True
@md_aaqil80274 жыл бұрын
Java Solution class Solution { Random random; int[] nums; public Solution(int[] w) { random = new Random(); nums = new int[w.length]; nums[0] = w[0]; for(int i = 1; i < w.length; i++) { nums[i] = nums[i - 1] + w[i]; } } public int pickIndex() { int n=random.nextInt(nums[nums.length-1])+1; int left=0,right=nums.length-1; while(left
@techdose4u4 жыл бұрын
👍
@kunalsinghgusain20704 жыл бұрын
Enough end this bucket. Come to the point man. You cleared the intent long ago but that extremely extra explanation made the video long. 🤣👍
@techdose4u4 жыл бұрын
🤣 Everyone doesn't get it as quickly as you did man 😅
@kunalsinghgusain20704 жыл бұрын
@@techdose4u that's true and I realized later when I actually coded it myself. Apologies if you found my comment rude.
@abhishekgautam10634 жыл бұрын
Very unclear problem statement :(
@techdose4u4 жыл бұрын
Yea. Not explained anything at all.
@abhishekgautam10634 жыл бұрын
@@techdose4u yes sir!
@yatri63299 ай бұрын
Kuch nhi samjh aya kya bol gya
@rishabhkumar81153 жыл бұрын
Thanks for this video. I was trying so hard to understand the question from the discussion section and everyone was using this cumulative array and I couldn't understand how it is helping. Now I am getting it finally!