Find the Duplicate Number - Floyd's Cycle Detection - Leetcode 287 - Python

  Рет қаралды 308,304

NeetCode

NeetCode

Күн бұрын

Пікірлер: 540
@NeetCode
@NeetCode 3 жыл бұрын
🚀 neetcode.io/ - I created a FREE site to make interview prep a lot easier, hope it helps! ❤
@nithishthomas1514
@nithishthomas1514 2 жыл бұрын
Can't you just use sum of arithmetic progression to find the ans quicker? 1,2,3,4,2 If there were n numbers in range 1 to n their sum would be n×(n+1)/2 = 10. Actual sum = 12 12- 10 = 2 1,2,3,3 =9 n*(n+1)/2 = 6 9-6 = 3
@hhcdghjjgsdrt235
@hhcdghjjgsdrt235 2 жыл бұрын
@@nithishthomas1514 ha ha ha ha
@onkarsingh-vu1ds
@onkarsingh-vu1ds 2 жыл бұрын
@@nithishthomas1514 was my 1st intuition too. I even submitted the code with this solution. Maybe the language in the question is ambiguous. The input can be [2,2,2,2,2] or [1,2,3,2,2]
@leventoz9530
@leventoz9530 Жыл бұрын
@@onkarsingh-vu1ds It says there are n+1 numbers from 1-n and only one repeated number, so all numbers from 1 - n must be present, plus the extra. @nithishthomas1514 appears correct.
@leungcheng4086
@leungcheng4086 11 ай бұрын
@@leventoz9530 This problem now actually have a testcase that the input is [2,2,2,2,2] although this is contradict to the problem description. I know that because I tried to submit with this solution lol
@shelllu6888
@shelllu6888 3 жыл бұрын
Your 1min introduction on this problem literally cracked up me :D Never think of saltiness can turn into such a fun intro. Will probably remember this problem and how to solve it for a long time :D Thanks for making this video!
@DanielRodrigues-bx6lr
@DanielRodrigues-bx6lr Жыл бұрын
I'll also always remember it because JomaTech made a meme video on it, and I tried learning it after that but failed miserably. Then NeetCode explains it flawlessly in one video. xD A great teacher can make all the difference.
@JihChiLee
@JihChiLee 3 жыл бұрын
This is the best video of explanation of Floyd’s algorithm I have seen so far…
@MichaelButlerC
@MichaelButlerC Жыл бұрын
This guy is seriously awesome 😎
@rajeshseptember09
@rajeshseptember09 Жыл бұрын
That's right. Even Floyd wouldn't have resolved this problem in 30 minutes. It goes on to say that given the nature of such requirements in an interview, certain solutions are best memorized so that you could use them in a different situation or if the same problem comes up again.
@epsilonator
@epsilonator 2 жыл бұрын
I absolutely love the fact that you code the solution right in front of us while explaining it, whereas other coding KZbinrs just show their already written code which sometimes becomes difficult to understand. Thanks a ton for your awesome videos
@alganyagiz8301
@alganyagiz8301 5 ай бұрын
agreed, it's way easier to understand code as its being written, even though it's entirely psychological lol
@dpsingh_287
@dpsingh_287 4 ай бұрын
@@alganyagiz8301 yeah it's like we see it step by step how the logic is built and code is written
@leungcheng4086
@leungcheng4086 11 ай бұрын
Thank you so much for the video of clear explaination! For the graph starting from 2:32, I think the outgoing pointer from node 0 should point at node 1 first. And then node 1 will point to node 3. Skipping the node that is pointed by 0 will struggle at the situation that element in 0 index is already the anwser. At last, really thank you for creating great website needcode with good videos of the explaination of solution!!
@allenlam5210
@allenlam5210 5 ай бұрын
Was thinking the same thing!
@shir35303
@shir35303 5 ай бұрын
My exact thoughts
@puzzle-headed-cat
@puzzle-headed-cat Ай бұрын
+ 1 to this, i got confused for a bit because of this, glad to get confirmation.
@akankshasharma7498
@akankshasharma7498 2 жыл бұрын
GOAT explanation. Everyone advised me to just memorize the algorithm, you're the only person to explain it to me.
@joeycopperson
@joeycopperson 3 жыл бұрын
That proof explanation was very good.. Even other big channels have failed to do it so smooth. thanks
@apyyymnmn3442
@apyyymnmn3442 Жыл бұрын
The proof isn't 100% right as he takes for granted that fast and slow will intersect though. But apart from that, everything was great
@joeycopperson
@joeycopperson Жыл бұрын
@@apyyymnmn3442 I guess he demoed it at 7:27 but maybe you're looking for mathematical proof?
@birukabza
@birukabza 7 ай бұрын
@@apyyymnmn3442 He did prove it in linked list cycle video
@yaremayaremchuk3608
@yaremayaremchuk3608 22 күн бұрын
@@apyyymnmn3442 watch his linked list cycle video, he proved it there. basically slow always increases reverse distance between them by 1 and faster decreases it by 2, which basically means that every step the distance decreases by 1 and eventually faster will catch slow again
@interviewprep6827
@interviewprep6827 3 жыл бұрын
This is the only explanation of Floyd's algorithm that I could understand... Thanks for this video...
@IshithaN
@IshithaN 2 жыл бұрын
This code s not working
@MohitKumar-dy3ep
@MohitKumar-dy3ep 9 ай бұрын
​@@IshithaNhe wrote fast[nums[fast]] just change it into nums[nums[fast]] then the code will work fine
@unmeshchougule5666
@unmeshchougule5666 2 жыл бұрын
Kudos! No one explained the algorithm better than this, thank you so much
@Alzmerch
@Alzmerch 2 жыл бұрын
I believe the head node at 2:35 should be 1 and not 0. 1 --> 3 --> 2 4. This may cause confusion for others, thought I'd point it out.
@guosun8090
@guosun8090 2 жыл бұрын
I agree with you. The head node is confusing
@osamaahmad8113
@osamaahmad8113 Жыл бұрын
I was losing my mind tryna understand why the headnode was 0. LOL thanks
@shellyyang1916
@shellyyang1916 Жыл бұрын
Actually, it should be 0 --> 1 --> 3 --> 2 4, so Neetcode forgot to draw the node "0", which is never reached. Because notice now slow and fast are starting from 0, rather than nums[0]. Hence, in the first step, slow will become 1, and fast will become 3. If they both starts from "1", then at the first step, slow will goes to 3, and fast will goes to 2, which would not work.
@shdnas6695
@shdnas6695 Жыл бұрын
@@shellyyang1916 why 0 1 3 2 4. Why this sequence? i mean the initial give was 1 3 4 2 2, so how it became 0 --> 1 --> 3 --> 2 4 :)
@vroomerlifts
@vroomerlifts 7 ай бұрын
Yes, I had been staring at the screen for quite some time and was searching for this.
@ajskjub5171
@ajskjub5171 2 ай бұрын
man you saved my day.. everyone was talking about how there should be slow and slow2 pointers in phase 2 but no one actually explained what is background story for this.. thanks a lot you are my hero :)
@asdfasyakitori8514
@asdfasyakitori8514 Жыл бұрын
I like the fact that you disliked this problem
@RM-bg5cd
@RM-bg5cd Жыл бұрын
These are the kind of questions that piss me the fuck off. if you get this question in an interview and missed out on class it's GG Thank you for your explanation as always though, this channel is a gold standard
@tesuji-go
@tesuji-go 3 ай бұрын
If someone submitted Floyd's algorithm in a PR I'd ask for them to be removed from the project. There is clever and there's batshit and Floyd's is batshit. Asking questions to test how people deal with graph theory is very different from asking for solutions only a crazy person would use. Are you telling me you guys are crazy and I should thank you for your time and leave? Stop hazing people. It's illegal in college it should be illegal in software interviews.
@diojoestar5178
@diojoestar5178 Ай бұрын
somehow i can tell you play league of legends
@juturtaur298
@juturtaur298 18 күн бұрын
Thankyou for the Humility toward us coders. God bless you.
@harpercfc_
@harpercfc_ 2 жыл бұрын
Very clean and understandable explanation. I would rewatch it for more times. Thank you for your great work!
@johnpaul4301
@johnpaul4301 2 жыл бұрын
Football fans are code monkeys too now. Hazard is finished btw
@yskida5
@yskida5 2 жыл бұрын
Up the blues
@anshaneja804
@anshaneja804 3 жыл бұрын
Your explanation was very clear, easily understandable. Thank you
@clintondannolfo714
@clintondannolfo714 2 жыл бұрын
Had to re-watch this to get the mathematical proof, thanks for the great explanation!
@funkyphyllo7150
@funkyphyllo7150 6 ай бұрын
Another way to think about Floyd's: (1) by the time "slow" enters the cycle ( slow=p), "fast" is p-many steps into the cycle. (2) in order to intersect, fast needs to catch up by (c-p) steps, so now both are (c-p) many steps into the cycle, and therefore p-many steps away from beginning of cycle ** let c be the length of the cycle (3) Therefore, iterating once each from the head and the point of fast-slow intersection, will guarantee that the two meet, and that they meet at the entry point to the cycle
@RohanRambhiya
@RohanRambhiya 8 ай бұрын
You know what when you said that it is very difficult to solve this in 30 mins even for the person who invented the algorithm made me relief. Thanks
@tanoybhowmick8715
@tanoybhowmick8715 2 жыл бұрын
Difficult problem, hard to solve without prior experience on it. Thank you so much.
@bharathithal8299
@bharathithal8299 2 жыл бұрын
Great solution and explanation but there's a small mistake in the linked list diagram. The first element is actually 1 and not 0. Great work, thanks a lot!
@The6thProgrammer
@The6thProgrammer Жыл бұрын
Yes and no. While you are correct that 1 should appear in the linked list visual, I think it should be (0)->(1) at the beginning because the 0 node is technically our head (always) that no other node will ever point to. When we are setting slow and fast to 0 we are basically starting at the head. This makes it clearer to think about conceptually since we can consider fast and slow as starting together on node 0. Otherwise it is unclear in the linked list visual where fast and slow begin.
@surajthapa5808
@surajthapa5808 10 ай бұрын
@@The6thProgrammer please can you also explain how fast =num[num[fast] is increasing by 2 position at a time.
@Abc-lr4bf
@Abc-lr4bf Жыл бұрын
wow bro you are so brutally honest and feels so nice to watch your tutorial
@vijayschadalavada
@vijayschadalavada 2 жыл бұрын
This is one hell of a tricky problem. I did it with hashset and thought I'm done but I'm not. Appreciate your explanation. Very intuitive. I had re-watch to understand better.
@astik2002
@astik2002 Жыл бұрын
hey can you explain me how fast = nums[nums[fast]] is moving two times? its clearly just one step ahead of slow pointer which is slow = nums[slow]]
@洪子軒北科大
@洪子軒北科大 Жыл бұрын
@@astik2002 the default value of slow, fast is 0, which is a default pointer point to the first element in the nums array. each value in the nums array is a pointer to next position (value 3 means point to index 3, value 2 means point to index 2), not the adjacent position. the next position may be adjacent position, may not. so nums[fast] moves fast pointer to the next position, nums[nums[fast]] move fast pointer to the next position again. compared with slow = nums[slow], which just move slow pointer to the next position one time.
@AbdulAziz-fp3hz
@AbdulAziz-fp3hz 2 ай бұрын
Hands down, this is the best explanation I’ve found regarding Floyd’s algorithm.
@JamesGourley-u7p
@JamesGourley-u7p Жыл бұрын
Such an excellent explanation of Floyd's algorithm - thank you NeetCode!
@teamo8033
@teamo8033 2 жыл бұрын
Throwing my Cracking The Coding Interview in the trash... you are all I need
@sulinPL
@sulinPL 4 ай бұрын
Thanks for breaking this down! I managed to crack it in time and space O(n) by myself, but space O(1) was a head-scratcher. Gayle McDowell’s "2.8 Loop Detection" in Cracking the Coding Interview had me thinking I needed a secret decoder ring. Found it here, and now I can finally put away the flashcards!
@michaelsafwat1953
@michaelsafwat1953 5 күн бұрын
I wasn't ready for this 💀
@faiqito6987
@faiqito6987 Жыл бұрын
you know its a beautiful algorithm when the code for it is so simple
@rahulsbhatt
@rahulsbhatt Жыл бұрын
The proof you made us understand is the best I will ever see for this algo. Thank you so much, man!
@jkyu2701
@jkyu2701 11 ай бұрын
I don’t like this type of interview problems either but have no choice but to solve it to get prepared. Big Thanks for your great video, it helped a lot❤
@Kuma117
@Kuma117 8 ай бұрын
Honestly, blows my mind how companies expect anyone to derive this relation without having seen it before.
@AnonYmous-yu6hv
@AnonYmous-yu6hv Жыл бұрын
You're right, I don't know why would anyone ask this question, nobody will know it unless they have super memory and saw it already and this doesn't let you learn anything about the interviewee.
@vdyb745
@vdyb745 2 жыл бұрын
The best and clear explanation I have found on this algorithm so far ! Thank you !!!!!
@aadityakiran_s
@aadityakiran_s Жыл бұрын
Very well explained. Thank you. It's pretty simple if you've already seen it. You're right. I also learnt a lot form the other solutions posted on LeetCode.
@ajitham5975
@ajitham5975 Жыл бұрын
Its safe to say, subscribing to neetcode is kinda the best decision I've ever taken in my life.
@finemechanic
@finemechanic 9 ай бұрын
Great explanation of everything starting with why it is a linked list and why it has to have a cycle and ending with the Floyd's algorithm.
@AnshViswanathan
@AnshViswanathan 6 ай бұрын
Never understood this problem until I watched this. Thank you!
@parulagrawal635
@parulagrawal635 4 ай бұрын
Loved the explanation:) Perhaps the cleanest explanation I've seen so far
@chetansingh2901
@chetansingh2901 2 жыл бұрын
whenever i fall in a frenzy over a leetcode problem....i just google it's neetcode solution. Great explanations man.
@krishankantray
@krishankantray 10 ай бұрын
I got this problem in my interview and the interviewer asked me to explain why this algo works, basically prove it
@johnpaul4301
@johnpaul4301 10 ай бұрын
What company? Google?
@shrayesraman5192
@shrayesraman5192 4 ай бұрын
I mean if you have seen this before then it's not too bad but if you haven't they don't want you.
@kevinwang8632
@kevinwang8632 Жыл бұрын
11:30 In the proof, the fast pointer was equal to P + 2c - x, but isn't that assuming the fast pointer only loops over the cycle once?
@johnlin2924
@johnlin2924 7 күн бұрын
this would happen in cases that, p >> c, in this case the intuition is imagine expanding the cycle however many times it takes until c > p, i.e. if the cycle is 1->2->3->1, you could arbitrarily say that the cycle is actually 1->2->3->1'->2'->3'->1*->2*(etc)->1, this expansion would guarantee that the fast pointer only oops over "the cycle" once
@kishoremohanavelu2968
@kishoremohanavelu2968 2 жыл бұрын
great explanation. Especially the maths explanation was really good!!
@tdx_1138
@tdx_1138 4 ай бұрын
About as good an explanation as possible for such a problem. Great job and subscribed!
@rajastylez
@rajastylez 3 жыл бұрын
I appreciate the brutal honesty at the start of this video lol.
@Emorinken
@Emorinken 3 ай бұрын
This question looks so complex only for the code to be so easy, thanks man
@niharbastia5740
@niharbastia5740 2 жыл бұрын
Amazingly explained ! God bless
@il5083
@il5083 Жыл бұрын
Wonderful explanation. Minor correction, if the cycle is small the fast pointer might have go though more than two cycles. So the more general equation is p = nc + x where c >= 0 They will still meet at the start of the cycle. The case in the video is easier to understand, though. I wouldn't figure this out with out the simpler case.
@asdfasyakitori8514
@asdfasyakitori8514 Жыл бұрын
He did mention it at 13:30
@il5083
@il5083 Жыл бұрын
@@asdfasyakitori8514I may skipped to the coding part, thanks.
@prakharkapisway8834
@prakharkapisway8834 11 ай бұрын
Thanks@@asdfasyakitori8514 , I was also having the same doubt .
@ruxiz2007
@ruxiz2007 2 жыл бұрын
Thanks so much, to be honest for so many years I could not get this straight until watching this.
2 жыл бұрын
man, this is such a golden explanation
@mr6462
@mr6462 2 жыл бұрын
If the company I am interviewing for asks me to solve it in constant space, I would leave the interview right away.
@tinymurky7329
@tinymurky7329 Жыл бұрын
I will cry if I got this question in intervew
@SaiyaraLBS
@SaiyaraLBS 3 ай бұрын
i would've cried if i didn't know it before.. but after knowing it's easy. it's not a fair question though... but if it comes now it will be easy if you already know it
@bigbigdog
@bigbigdog Жыл бұрын
I was asked this question during a tech screen. Was not able to figure it out on my own and I ended up doing the sorting solution.
@fcoatis
@fcoatis 3 жыл бұрын
Best Floyd´s explanation ever. I´ve been trying to get it since I´ve watched Joma´s video 'If Programming Was An Anime'
@TechnicalStudio
@TechnicalStudio 3 жыл бұрын
Your Videos are so useful. ❤️
@johnpaul4301
@johnpaul4301 10 ай бұрын
One thing I'm having a hard time to fully understand. How does returning the index work here? Like I don't understand how returning the index will give us the correct value since the question is asking for the value of the duplicate but we're just returning the index based on the graphs you drew
@andreacucchietti1772
@andreacucchietti1772 2 ай бұрын
To understand better Floyd's algorithm I came up with an example that I think is cool and I wanted to share. Think as the slow and fast pointers as two runners and each step of the slower as a meter. The second runner B is twice as fast as the first runner A. They start from the same point and they reach the zero of a circular track running. We can count the meters in the circular track in positive meters clockwise and negative anticlockwise. The distance between the starting point and the track is X. So, when A reaches the track, B is already X meters in. They keep running and B is going to complete 2 cycles when A completes the first. When A has X left, then B is going to have 2X left because he is twice as fast. Since B started at X, when he has 2X left, he is in -X, so he is at the same point as A when A misses X meters! To get to the start we have just to move of X steps at A pace.
@linli7049
@linli7049 3 жыл бұрын
Fantastic explanation about the math proof of Floyd's algorithm!!!
@rekhasrivastava5114
@rekhasrivastava5114 2 жыл бұрын
Best Explanation I was having idea of Floyd algorithm but I was not clear about it. Your explanation clears my all doubt Thank You so much
@mahletlulsegedyifru3465
@mahletlulsegedyifru3465 11 ай бұрын
Thank you so much ! This is the best explanation of Floyd's algorithm
@michaelchen3631
@michaelchen3631 29 күн бұрын
I think that a very important thing to note is that: - Zero MUST point to a number. - But NO number can point to zero - zero not included in boundaries of numbers - This guarantees that zero MUST be attached to a cycle where one number has two pointers - can't have full loop with last number pointing back to zero So we can confidently start our algorithm from zero every time.
@riteshsaha6881
@riteshsaha6881 2 жыл бұрын
Thank you for helping me understand Floyd's algorithm.
@vikaskumarl3719
@vikaskumarl3719 2 жыл бұрын
The absolute best explaination I found on KZbin for Floyd's algo
@deresel4874
@deresel4874 2 жыл бұрын
what a champ! Thanks for explaining this algo, i had trouble visualising the slow1==slow2 intersecting part.
@piyushraj8701
@piyushraj8701 2 жыл бұрын
Omg. It was just wow. No one can explain better now. Finally satisfied with Floyd explanation. Thanks a lot sir🙏🙏🙏
@emtikucz1553
@emtikucz1553 2 жыл бұрын
for numbers it can be made much easier I think. 1) sum all 2) sum of 1÷n is: n*(n+1)/2 3) result = (sum all) - (sum 1÷n)
@JonahDienye
@JonahDienye 2 жыл бұрын
🤦🏾‍♂️
@nikhil199029
@nikhil199029 2 жыл бұрын
@@JonahDienye why fcaepalm? This seems correct
@JonahDienye
@JonahDienye 2 жыл бұрын
@@nikhil199029 oh yes! The facepalm was for myself, for not figuring this approach out. However, this approach does not work if a number is repeated more than once.
@shubhammaurya3671
@shubhammaurya3671 2 жыл бұрын
but it will only work if number is repeated only once
@juanmoscoso0
@juanmoscoso0 2 жыл бұрын
numbers from 1-n aren't guaranteed to repeat
@MP-ny3ep
@MP-ny3ep Жыл бұрын
Amazing explanation as always. Thank you so very much !!!
@brian4084
@brian4084 3 жыл бұрын
Great video. In the Drawing Explanation, is there a mistake? Shouldn't it be 0 -> 1 -> 3?
@fdk9913
@fdk9913 3 жыл бұрын
No, think about the first element(0) in the drawing explanation as the consistent point because the numbers in the list can only go from 1 to nth-index value. So, no way will any of the values point to 0 since it doesn't fall in with the requirements of the problem.
@PauloTheDev
@PauloTheDev 3 жыл бұрын
I drew this multiple times and the only way this makes sense is if it is 0 -> 1 -> 3
@srikanthperne2057
@srikanthperne2057 2 жыл бұрын
We can solve it in a much simpler way using indices: def findDuplicate(self, nums: List[int]) -> int: res = 0 for num in nums: if nums[abs(num)] < 0: res = abs(num) nums[abs(num)] = -nums[abs(num)] for i, num in enumerate(nums): if num < 0: nums[i] = -num return res
@danafaiez3663
@danafaiez3663 Жыл бұрын
I like that solution too but this solution modifies the array and the problem statement in Leetcode says "You must solve the problem without modifying the array ."
@srikanthperne2057
@srikanthperne2057 Жыл бұрын
We can iterate over the array one last time and modify the -ve values back to +ve. That way the array remains unchanged.
@rushikeshneelamsetty9693
@rushikeshneelamsetty9693 2 жыл бұрын
Hello @NeetCode, I have a different solution for this problem and I would like you to review it and tell me if it would be appropriate to use it in an interview. So the approach is, since there are integers only in the range 1 to n and only one element is repeated use the formula for 'sum of n natural numbers' i.e., n*(n+1)/2 and we can find n by nums.size() -1. After finding the natural sum and the total sum of the array and finding the difference between them would be the answer.
@yskida5
@yskida5 2 жыл бұрын
This was my approach as well, but I think the problem with this kind of solution is cases where a # is repeated several times, i.e. [1, 2, 2, 2, 3]. It's ambiguous which digit is causing the difference if we do not know the frequency of said repeated digit. I may be wrong tho, would love input from others
@nikhil_a01
@nikhil_a01 2 жыл бұрын
@@yskida5 You're correct. If you code this solution on LeetCode it will fail the test case [2, 2, 2, 2, 2].
@imtheone007
@imtheone007 2 жыл бұрын
sooo good explanation, i watched a bunch of videos, until i landed on your video and got it
@prammar1951
@prammar1951 Жыл бұрын
WOW, really loved that proof. Never studied this in uni thanks for your help
@ianokay
@ianokay 7 ай бұрын
At 11:35 you say "Plus C again", but this is the most profound and mysterious part of the entire problem, and you just casually and flippantly throw that out there as if it's intuitive or known, while trying to intuitively explain the problem. You're trying to grant us intuition with a magical answer that reveals no intuitive understanding. 😬💡
@smilejayden-553
@smilejayden-553 2 жыл бұрын
In [1,3,4,2,2] example, the digram omitted the node “1”. Except that, it is very good explaining! Thank you very much 🙂
@shenbomo
@shenbomo 2 жыл бұрын
I think it is correct as is, there should be no node "1", since he has mentioned that to use the value as the index position for the pointer, and nums[0] is 1, and nums[1] indeed has the value of 3. He also has mentioned that because the integers start from 1 to n, and using any value of 1...n (non-zero) as index position will never give you nums[0] as a node in the graph.
@fangzhengchen7620
@fangzhengchen7620 2 жыл бұрын
The intro makes total sense why I wouldnt never think this is a linkedlist problem
@vedantshinde2277
@vedantshinde2277 3 жыл бұрын
Neetly explained! I'm bad with time complexities, I'd love for you to break down the time complexity as well.
@pikachupika7203
@pikachupika7203 3 күн бұрын
I believe for this problem, its better to study the bit manipulation and binary search solution. As floyd cycle is not super intuitive in an interview setting.
@ЕленаДоманская-к5х
@ЕленаДоманская-к5х Жыл бұрын
You are really talanted in explaning complicated things, even I got it) Thank you
@damandeepdhillon4592
@damandeepdhillon4592 7 ай бұрын
Best explanation for A solution. Respect.
@jaythebadyo
@jaythebadyo 2 жыл бұрын
The best explanation of Floyd's algorithm!
@algosavage7057
@algosavage7057 3 жыл бұрын
And to be more accurate, I think it's better to initialize slow and fast with nums[0] instead with 0
@nevermore7755
@nevermore7755 3 жыл бұрын
It's like Leafy teaching me how to land a FAANG job. Respect!
@학교-m5c
@학교-m5c Жыл бұрын
The fast pointer is not guarranteed to loop twice if p is really long and c is short, it will loop more than 2 so the distance fast pointer travelled becomes P + nC - X, at which im lost
@algosavage7057
@algosavage7057 3 жыл бұрын
Dude, it seems that in 2:38 the first node is 1, not 0. As I understand inside the nodes we write the elements of the array, not indexes.
@spaceface2288
@spaceface2288 2 жыл бұрын
Yeah, I guess its a small mistake on his part, but the awesome explanation covers up for that mistake lol.
@amitupadhyay6511
@amitupadhyay6511 2 жыл бұрын
Wow, i was in depression thinking i could not even solve this problem. However ,after listening you in first 2 minutes, I am like, " I am not that dumb eh " lol
@vuongbinhan
@vuongbinhan Жыл бұрын
Ah yes the "trivial" cycle linked list for a seemingly easy problem, this is why I suck so badly at LC style interview :(
@matheusmenezes4702
@matheusmenezes4702 10 ай бұрын
Thank you for this content!! The best explanation about this algorithm
@nw3052
@nw3052 Жыл бұрын
This explanation is definitely the best out there, but I didn't quite get the last point where p is really long and the fast pointer circled n times. For the math to work we need to have c multiplied by n/2 in the slow pointer part of the equation, but that would mean that the slower pointer travelled the cycle half the times of the fast pointer (n/2 times), which is not exactly intuitive.
@user-tk7sc4gz2v
@user-tk7sc4gz2v Жыл бұрын
Great Explanation, modified to avoiding while True slow, fast = nums[0], nums[nums[0]] while fast != slow: slow = nums[slow] fast = nums[nums[fast]] slow2 = nums[0] slow = nums[slow] while slow != slow2: slow2 = nums[slow2] slow = nums[slow] return slow
@IN-krude
@IN-krude 9 ай бұрын
There is an easy way to do all this. Calculate the sum of N natural number as n(n+1)/2. Then, subtract this value from the sum of the array to get a duplicate number. This is O(n) with constant space.
@HimanshuTradesForex
@HimanshuTradesForex 8 ай бұрын
Wont work ,as there are more than 1 duplicates
@supercarpro
@supercarpro 2 жыл бұрын
I like how you quickly removed the perimeter around the linked list
@aadil4236
@aadil4236 Жыл бұрын
12:51 It should p === x. You said p === 0. But I got the point. Great explanation as always!
@onethousandtimes6294
@onethousandtimes6294 6 ай бұрын
One thing that made me confused is when he say "the thing in index 0 is never gonna be part of the loop". Which is intuitively true until you actually realize that the duplicate number can be at the index 0. This means that the linked list representation will be a whole loop (Circle loop). And with the formula that is proven, they will have p of 0 and x of 0 which means it will return the first number (which will meet in other index).
@dk20can86
@dk20can86 2 жыл бұрын
Thanks for the reassurement that this was a ridiculous question, it totally stumped me haha
@nothingisreal6345
@nothingisreal6345 Жыл бұрын
I mean for loop detection it is useful. But could it be used for the general case to detect if an array of objects contains some duplicates?
@Cheng-K
@Cheng-K Жыл бұрын
Thank you so much for the wonderful explanation! Really liked it
@sezzario
@sezzario 2 жыл бұрын
Amazing explanation as always :)
@kartikeyamishra3964
@kartikeyamishra3964 5 ай бұрын
Incredible explanation man, thanks a ton
@stylisgames
@stylisgames 6 ай бұрын
``` slow = nums[slow]; fast = nums[nums[fast]]; ``` This is absolutely wild. Took me so long to even figure out that each value is pointing to the value at that index which is how the linked list representation is built. This could've used more explanation.
Война Семей - ВСЕ СЕРИИ, 1 сезон (серии 1-20)
7:40:31
Семейные Сериалы
Рет қаралды 1,6 МЛН
번쩍번쩍 거리는 입
0:32
승비니 Seungbini
Рет қаралды 182 МЛН
I'VE MADE A CUTE FLYING LOLLIPOP FOR MY KID #SHORTS
0:48
A Plus School
Рет қаралды 20 МЛН
LRU Cache - Twitch Interview Question - Leetcode 146
17:49
NeetCode
Рет қаралды 314 М.
Subarray Sum Equals K - Prefix Sums - Leetcode 560 - Python
15:19
Making an Algorithm Faster
30:08
NeetCodeIO
Рет қаралды 186 М.
How I would learn Leetcode if I could start over
18:03
NeetCodeIO
Рет қаралды 753 М.
Programming Anime: Floyd's Algorithm Explained
19:44
JomaClass
Рет қаралды 269 М.
Coin Change - Dynamic Programming Bottom Up - Leetcode 322
19:23
LeetCode was HARD until I Learned these 15 Patterns
13:00
Ashish Pratap Singh
Рет қаралды 694 М.
Dynamic Programming isn't too hard. You just don't know what it is.
22:31
DecodingIntuition
Рет қаралды 231 М.
для всей семьи
0:56
Стакановец
Рет қаралды 191 М.
This thing is CRAZY 🤯 #shorts
0:20
House of Highlights
Рет қаралды 48 МЛН
КОРОЧЕ ГОВОРЯ, НЕДЕЛЯ БЕЗ ТЕЛЕФОНА
3:54
🪄Вечная спичка #diy #выживание #поход
1:00
Короче, ВИ
Рет қаралды 2,8 МЛН