Add Two Numbers - Leetcode 2 - Python

  Рет қаралды 262,111

NeetCode

NeetCode

Күн бұрын

Пікірлер: 240
@NeetCode
@NeetCode 4 жыл бұрын
🚀 neetcode.io/ - A better way to prepare for Coding Interviews
@oanamanaljav
@oanamanaljav 3 жыл бұрын
Seems like the code is not working. Showed me the wrong result when compile.
@e-raticartist
@e-raticartist Жыл бұрын
hearing "hey guys i'm still unemployed so let's solve a leetcode problem today" and knowing you became a software engineer at google is so real and inspiring bro, thanks
@alwin5995
@alwin5995 11 ай бұрын
Bruh he left job at amazon, and decided to voluntarily be unemployed. Dude's been a genius all along.
@rohitkumarsinha876
@rohitkumarsinha876 3 жыл бұрын
"hey guys i am still unemployed so lets solve a problem " this is savage bro
@farnazzinnah8541
@farnazzinnah8541 3 жыл бұрын
he earns fro youtube tho
@samirpaul2
@samirpaul2 2 жыл бұрын
😂
@computergeek5657
@computergeek5657 2 жыл бұрын
KZbin hired him
@neerajmahapatra5239
@neerajmahapatra5239 2 жыл бұрын
Now he is at google
@omkarjadhav8482
@omkarjadhav8482 2 жыл бұрын
💯😂
@chair_smesh
@chair_smesh 2 жыл бұрын
I get so inspired/motivated when you mention unemployment in your old videos because of where you ended up
@bigrat5101
@bigrat5101 2 жыл бұрын
"hey guys i am still unemployed so lets solve a problem " this one cracked me up because right now all your efforts paid off and look back, we all have been there..ah what a journey!!!
@smalldoggo3704
@smalldoggo3704 3 жыл бұрын
that intro hit me different
@NeetCode
@NeetCode 3 жыл бұрын
lol
@khouloudsaid2479
@khouloudsaid2479 3 ай бұрын
hhhhhhhhhhh me too
@mehmetnadi8930
@mehmetnadi8930 2 жыл бұрын
I've been watching your solutions for a while now and I'm just so happy that I finally started to solve problems like the way you do. Thank you so much!!
@snoudoubts1745
@snoudoubts1745 2 жыл бұрын
That beginning took me by surprise, instantly made my evening better. Thanks
@syafzal273
@syafzal273 10 ай бұрын
Awesome, I love how you dealt with all the edge cases without cluttering the code
@anantmulchandani709
@anantmulchandani709 2 жыл бұрын
Congratulations that you are now employed!! Happy for you!
@Eftahhh
@Eftahhh 4 жыл бұрын
So simple, thank you. I was casting the linked list values to strings and reversing them, then casting them back to ints and adding them... needless to say I was making spaghetti. Your example is very clean!
@prudvi01
@prudvi01 3 жыл бұрын
lol that was my initial solution as well! got dirty real quick
@liferayasif9382
@liferayasif9382 3 жыл бұрын
I did same, thanks
@UnknownSend3r
@UnknownSend3r 3 жыл бұрын
@@prudvi01 I used an if statement inside a while loop, would that be wrong even if it works, if not what's wrong with it ? As in does the solution have to be a linked list.
@BromaniJones
@BromaniJones 2 жыл бұрын
I did the same. I'm not convinved it's any worse than the solution presented in the video. looping through two linked lists (and a third for the output) is O(n) time complexity.
@gustavotelez9795
@gustavotelez9795 2 жыл бұрын
def addTwoNumbers(l1,l2): l1.reverse() l2.reverse() l1s= str(l1) l2s= str(l2) l1s= "".join(l1s) l2s= "".join(l2s) l1 = "" l2 = "" for i in range(1, len(l1s), 3): l1 +=l1s[i] for i in range(1, len(l2s), 3): l2 +=l2s[i] l1s=int(l1) l2s=int(l2) res=l1s+l2s res= str(res) res= list(res) res.reverse() return res
@philhamlin7935
@philhamlin7935 3 жыл бұрын
Excellent! Clear and plain explanations, and it's so much cleaner when hand mark-up is by pen instead of by mouse. :) This is linked in LeetCode as "optimized solution explained" on the problem itself, but it'd be faster to take: carry = val // 10 val = val % 10 ...and make it instead: carry = 1 val = val - 10 The modulus approach is fantastic for expanding our algorithm to support adding up three or more arrays, but in our use case carry will always be 0 or 1.
@stementhusiast816
@stementhusiast816 3 жыл бұрын
You would require 'if' statements. if val >= 10: carry = 1 val = val - 10 Which would reduce the elegance of code
@khatharrmalkavian3306
@khatharrmalkavian3306 2 жыл бұрын
Nothing about this problem is elegant or worth optimization.
@mu0325
@mu0325 3 жыл бұрын
I traversed through both linked list and got the actual numbers, added them, then created a linked list with the result's digits as nodes.
@inspisiavideos8542
@inspisiavideos8542 3 жыл бұрын
hi, Please let me know. Why is the value divided by 10? I'm learning how to code and I don't know where he got the number 10? (on minute 7:29)
@danielwilczak7833
@danielwilczak7833 3 жыл бұрын
​@@inspisiavideos8542 You divide by 10 so that you can add it to the next number which will be in the next 10's place. For example: if you took 25 + 26 if you add 5 + 6 and then divide by 10 you'll get 1. So i take my one and add it to the next 10's place which is 2 + 2 + 1 that i got from carrying the number which will total 51.
@inspisiavideos8542
@inspisiavideos8542 3 жыл бұрын
@@danielwilczak7833 Thank you so much!!! I got an internship during this Summer as QA and just finished it but I asked for an extension and if I could get it this time as Dev. They said yes. I have coded before with courses on how to make websites but I have never done code questions. Basically this next week is my first week. It’s so hard to get a job so they told me that they don’t have entry level positions and senior positions are more than likely ending up on people who are already in the company. So basically I’m learning as much as I can during my spare time to then perhaps they let me stay after the internship extension ends by the end of the year.
@philhamlin7935
@philhamlin7935 3 жыл бұрын
@@inspisiavideos8542 Congrats on your internship! Calling out 10 as a "magic number" is really great - bare numbers with no evident explanation can cause a lot of confusion in code, so 10 could be a constant called NUMBER_BASE since we're just using decimal notation here. For extra fun, make it not a constant, and adapt the algorithm to work in number bases other than 10!
@inspisiavideos8542
@inspisiavideos8542 3 жыл бұрын
@@philhamlin7935 hey thanks! My internship was supposed to end in August but was extended to the end of December. I’ve been applying to other companies but nothing yet even though I have projects on my portfolio. My internship manager told me to stay alert when an opening occurs and apply. 2 positions opened and I applied there this week. Hopefully they’ll let me know and I be ready for a test code. The company has many teams so probably the person who sees my resume doesn’t know me yet.
@rotors_taker_0h
@rotors_taker_0h Жыл бұрын
For some reason it was extremely easy problem for me, first time that I just saw the solution instantly in full (unlike all “easy” ones before) and was so surprised of everyone’s animosity to this problem, lol.
@passionatechristianworker
@passionatechristianworker 7 ай бұрын
i'm amazed at your ability. it's the nuances in the code that's the hardest to figure out. kudos to you.
@pratikshanaik4143
@pratikshanaik4143 2 жыл бұрын
Better explanation than the official solution explanation.
@MrYosuko
@MrYosuko 9 ай бұрын
The intro slapped me back into reality. As always, thanks for the awesome explanations 😄
@NeilSharma-u5n
@NeilSharma-u5n 2 ай бұрын
The first medium LL problem I could solve with optimized code.
@anthonypeters1797
@anthonypeters1797 2 жыл бұрын
Couldn’t have solved this without you. Thank you so much
@alok7485
@alok7485 2 жыл бұрын
Can you please explain what will be the time complexity and space complexity for this piece of code in example?
@SweVillian-mt6nk
@SweVillian-mt6nk 9 ай бұрын
This intro make this video my favorite one 😂. Could be a useful cue to remember the solution in an interview even.
@raymondcordero9718
@raymondcordero9718 Жыл бұрын
By far the best explanation of this problem I’ve seen 👏 Thanks for sharing
@oooo-rc2yf
@oooo-rc2yf 3 жыл бұрын
If the person teaching these is unemployed what chances do we have...
@fernandoplak6925
@fernandoplak6925 Ай бұрын
rofl
@techbrojoe
@techbrojoe 3 жыл бұрын
Thanks for making this. Trying this problem is the first time I've ever tried using a Linked List, so this helped solidify the solution LeetCode provides.
@alok7485
@alok7485 2 жыл бұрын
Can you please explain what will be the time complexity and space complexity for this piece of code in example?
@passionatechristianworker
@passionatechristianworker 7 ай бұрын
"you probably do but you might think you don't". Haha, thanks for the encouragement.
@shooby117
@shooby117 11 ай бұрын
"hey guys i am still unemployed so lets solve a problem" mans representing his entire audience 😂😂😂
@anamikaborah5393
@anamikaborah5393 9 ай бұрын
Love how you started the video! xD You made my life easier by posting these videos. Great work! :) :D
@vinaykumar-gg4mx
@vinaykumar-gg4mx 3 жыл бұрын
A complete beginner question, how to call and declare the inputs for addTwoNumbers function, just to test the program !
@ishaanbhalla396
@ishaanbhalla396 2 жыл бұрын
Man I was super stressed out solving these leetcodes, but the " Hey I am still unemployed" made my day! LMAO
@serpent2776
@serpent2776 6 ай бұрын
I am so happy that LC decided to give us reversed lists for this problem
@MatthewPostrel
@MatthewPostrel Жыл бұрын
Explanation was crystal clear and helped me solve the problem super quick. Thanks!
@EranM
@EranM 6 ай бұрын
"Hey guys, I'm still unemployed.." Many kisses for you neet! you make me laugh.. And relax... To the best ASMR Channel OUT-THERE!!!! Please go back to this microphone and keyboard, and relaxed voice!!!!!!!!! damn I enjoy this
@DracosThorne
@DracosThorne Жыл бұрын
NC: You do probably remember how to add two numbers together Me: You severely overestimate my abilities
@__________________________6910
@__________________________6910 3 жыл бұрын
You are best. I always pause ads blocker for you.
@bulkan.evcimen
@bulkan.evcimen Жыл бұрын
this explanation is much better than the leetcode editorial
@tsunningwah3471
@tsunningwah3471 11 ай бұрын
can anyone tell me why we're returning the dummy.next and not dummy itself? wont we be able to access every other element if we just return dummy?
@jaisinha1378
@jaisinha1378 2 жыл бұрын
Only Platform I choose for any coding explanation
@whatdoiputhere5089
@whatdoiputhere5089 3 жыл бұрын
Dude, thankyou for this solutions. They are helping me alottttt! Also, if you could please make a video on intersection of two linked lists
@alok7485
@alok7485 2 жыл бұрын
Can you please explain what will be the time complexity and space complexity for this piece of code in example?
@Silver-lu1dt
@Silver-lu1dt 10 ай бұрын
This is the way I learnt about pointer, I can't believe it
@adityadixit1404
@adityadixit1404 2 жыл бұрын
To deal with edge case just before . return dummy.next write If carry==1: cur.next= ListNode (1)
@qazianeel
@qazianeel 2 жыл бұрын
I have interview on 21st March, there is no way I am gonna pass :( This level of programming is going above my head
@supriyamanna715
@supriyamanna715 2 жыл бұрын
kaya hua? Pass kiya tumne?
@alok7485
@alok7485 2 жыл бұрын
Did u pass?
@Davidsito44
@Davidsito44 Жыл бұрын
how did it goes?
@nivethanyogarajah1493
@nivethanyogarajah1493 Ай бұрын
Legendary Introduction!
@siruitao
@siruitao 2 жыл бұрын
Haha, now you are so employed! Thanks for these great contents!
@Moon-li9ki
@Moon-li9ki 6 ай бұрын
I'm really proud of mylsef. I finally managed to solve a medium problem by myself, although my solution was slow as hell xd
@stylisgames
@stylisgames 5 ай бұрын
I was able to solve this one, but did not think of dividing the current sum by 10 and using Math.floor() to get the first digit as the carry number, and then using modulo to get the second number aka the current sum. So darn clever! Instead I converted the sum to a string and grabbed the values by index.
@m0sh3
@m0sh3 11 ай бұрын
This code only passes 1365/1568 test cases. Update needed.
@tomonkysinatree
@tomonkysinatree 5 ай бұрын
I was really close to the solution on this one. I had an extra node at the end because I was creating my node in cur instead of cur.next(). Slowly getting better at these
@heyyy_rosa4520
@heyyy_rosa4520 3 жыл бұрын
This solution is so elegant.
@wlcheng
@wlcheng 2 жыл бұрын
I am very happy for you that you are employed at Google now. 😀
@bizdep6237
@bizdep6237 3 жыл бұрын
@NeetCode Could you please explain the time complexity of the problems you solve? It will be really useful for us.
@wlockuz4467
@wlockuz4467 2 жыл бұрын
For this one it should be O(n + m), where n is length of first linked list and m is length of second linked list.
@predatorgaming895
@predatorgaming895 2 жыл бұрын
@@wlockuz4467 no bro... Either O(n) or O(n+1) where n is the length of linked list which has more nodes
@alok7485
@alok7485 2 жыл бұрын
Can you please explain what will be the time complexity and space complexity for this piece of code in example?
@likkiii07
@likkiii07 Жыл бұрын
@@alok7485 Time complexity will be O(max(n, m)) and Space complexity will be O(max(m,n))
@asmamir7878
@asmamir7878 18 күн бұрын
Nice opening! I'm also still unemployed... 😁
@miyamotomusashi4556
@miyamotomusashi4556 2 жыл бұрын
Wow, this was very well explained!
@programlamaicin
@programlamaicin 2 жыл бұрын
Thank you for clean explanation. When 2 ListNode has different sizes you better check for l1 is None or not otherwise you'll have an runtime error. v1 = l1.val if l1 is not None and l1.val else 0 v2 = l2.val if l2 is not None and l2.val else 0
@plankton383
@plankton383 2 жыл бұрын
He does that already. “if l” is short for “if l is not None”.
@alicia8170
@alicia8170 2 жыл бұрын
At the start of the loop cur = dummy. On the first iteration you are assigning cur.next (aka dummy.next) with the first digit of the solution. So now dummy.next equals the head node of the solution so at the end we return dummy.next. dummy.next will always point to this head node no matter what cur gets changed to.
@alicia8170
@alicia8170 2 жыл бұрын
I quote your response to ask the question further. As I understand, cur = dummy means let cur be dummy, but they are not the same one. I still don't understand whey cur.next will change dummy.next. Did I miss anything? Thank you so much!
@oliverbao4925
@oliverbao4925 10 ай бұрын
@@alicia8170 hi yeah i'm wondering the same thing - although we didn't reference dummy at all or change its value, it gets built on as we change cur and cur.next - is this a python binding or pointer issue?
@shantipriya370
@shantipriya370 6 ай бұрын
wonderful explanation
@IvanRadonjic-j9f
@IvanRadonjic-j9f 10 ай бұрын
# Definition for singly-linked list. # class ListNode(object): # def __init__(self, val=0, next=None): # self.val = val # self.next = next class Solution(object): def addTwoNumbers(self, l1, l2): """ :type l1: ListNode :type l2: ListNode :rtype: ListNode """ def reverse_in_place(head): before = None temp = head while temp is not None: after = temp.next temp.next = before #flip pointer before = temp #cross 'gap' temp = after # move temp over return before #before is the new head of reversed LL l1 = reverse_in_place(l1) l2 = reverse_in_place(l2) temp_l1 = l1 l1_val = "" temp_l2 = l2 l2_val = "" while temp_l1 is not None: l1_val += str(temp_l1.val) temp_l1 = temp_l1.next while temp_l2 is not None: l2_val += str(temp_l2.val) temp_l2 = temp_l2.next total = int(l1_val) + int(l2_val) total = str(total) temp_out = ListNode(int(total[0])) new_LL = temp_out for i in range(1, len(total)): if temp_out.next is None: temp_out.next = ListNode(int(total[i])) temp_out = temp_out.next new_LL = reverse_in_place(new_LL) return new_LL This is my brute force method for this problem but i dont think its THAT bad on time and space complexity LOL what do you guys thing
@pahul79
@pahul79 Жыл бұрын
thanks for making these videos man, your awesome
@TheEllod
@TheEllod 2 жыл бұрын
nulll and zero are different, you should instead append the while statement to while l1 or l2 or carry>0
@jaspreetsahota1840
@jaspreetsahota1840 11 ай бұрын
In python, 0 evaluates to its Boolean value (False) in a conditional clause. So it's fine to just have carry.
@TheEllod
@TheEllod 11 ай бұрын
@jaspreetsahota1840 good to know!
@DanielSmith-uj7rr
@DanielSmith-uj7rr 3 жыл бұрын
BRO! UNIQUE..!! "Hey Guys, I am still UNEMPLOYED so let's solve a problem!" Lmao!😂
@maharshibiswas3557
@maharshibiswas3557 Жыл бұрын
Inspirational first line
@ahmetrauf2195
@ahmetrauf2195 11 ай бұрын
great explanation!
@ozgeylmaz8685
@ozgeylmaz8685 2 жыл бұрын
Great video and great channel I am very excited to discover this channel I hope I benefit from this channel a lot .Thanks a lot😊
@dr.merlot1532
@dr.merlot1532 3 жыл бұрын
My sentiments exactly. If NeetCode is unemployed, what chances do we have...
@NeetCode
@NeetCode 3 жыл бұрын
Well.. not anymore :p
@dr.merlot1532
@dr.merlot1532 3 жыл бұрын
@@NeetCode In my heart and mind, you are still unemployed.
@computergeek5657
@computergeek5657 2 жыл бұрын
KZbin hired u👍
@MrBear-no7iq
@MrBear-no7iq 3 жыл бұрын
Thank you !! I finally understand it now
@NabeelGm
@NabeelGm 2 жыл бұрын
Can someone explain why we don't use the first dummy list node? Why not use dummy.val and assign?
@gimmeadollr
@gimmeadollr 2 жыл бұрын
I think it's because we want the logic to be "the next thing is ___" for every iteration, so we make a dummy list node and immediately start with our logic (the next thing for the dummy node is ___). If you use dummy.val, you have the first step do the logic of "the value here is ___" and then the later steps are "the next thing is ___" which is more inconvenient to write. That's how I thought of it, not sure if that's the right way to think about it.
@asmahamdym
@asmahamdym Жыл бұрын
Wow this is so clean✅✅ I brute- forced my way to this problem and it's functional but really ugly 😀
@InfoBuzz1130
@InfoBuzz1130 2 жыл бұрын
LOVE you my GURU your awesome!!!
@techenthusiast3966
@techenthusiast3966 2 жыл бұрын
Here after when you got job in Google.... congratulations:)
@noumaaaan
@noumaaaan 3 жыл бұрын
A little confused,how are we adding in reverse order? we're just adding v1 and v2 which is normal addition isn't it?
@khatharrmalkavian3306
@khatharrmalkavian3306 2 жыл бұрын
The digits are in reverse order.
@symbol767
@symbol767 2 жыл бұрын
0:00 Lol now you're at Google. Here I am just trying to get Amazon or Microsoft now. Awesome solution, I managed to actually solve this one myself but wanted to see your way of doing it, much cleaner. Thank you! Liked!
@ABagOfLag
@ABagOfLag 8 ай бұрын
i solved it using more memory but it eliminates thinking about edge cases: nums1, nums2 = [], [] cur = l1 while cur: nums1.append(cur.val) cur = cur.next cur = l2 while cur: nums2.append(cur.val) cur = cur.next nums1 = nums1[::-1] nums2 = nums2[::-1] num1 = int(''.join(map(str, nums1))) num2 = int(''.join(map(str, nums2))) vals = [] number = str(num1 + num2) for c in number: vals.append(int(c)) dummy = ListNode(0) cur = dummy while vals: cur.next = ListNode(vals.pop()) cur = cur.next return dummy.next
@ABHINAVKUMAR-pl4iw
@ABHINAVKUMAR-pl4iw 2 жыл бұрын
you are the legend
@dreamingaparisdream3178
@dreamingaparisdream3178 3 жыл бұрын
I got some errors when I ran your exact code. Is your solution missing the case when the highest position creates a carry of 1?
@yinglll7411
@yinglll7411 3 жыл бұрын
you might have missed the "+ carry" bit when summing up the "val"
@dorb1337
@dorb1337 Жыл бұрын
while l1 or l1 or carry:
@sangpark7656
@sangpark7656 Жыл бұрын
what's the function of next and val do?
@02devavratkumarmahato11
@02devavratkumarmahato11 4 ай бұрын
Why can't we just return cur.next ??
@02devavratkumarmahato11
@02devavratkumarmahato11 4 ай бұрын
I mean the cur is pointing to dummy right? So just print it right idk if I'm right
@AdityaRaut-l6p
@AdityaRaut-l6p 3 ай бұрын
i think that will skip first value
@yvettcodes
@yvettcodes 7 күн бұрын
What is the time and space complexity?
@nerdclapper1983
@nerdclapper1983 Жыл бұрын
There is a VERY simple solution. Simple go through both lists and for each one create a string with the values. Then reverse both strings, convert them to int and add them together. Then convert that to a string and go through each char and create a new Node in the new LL, still O(n) def addTwoNumbers(l1: ListNode, l2: ListNode) -> ListNode: # treat them as string and reverse them s1 = "" cur = l1 while cur: s1 += str(cur.val) cur = cur.next s2 = "" cur = l2 while cur: s2 += str(cur.val) cur = cur.next s1 = s1[::-1] s2 = s2[::-1] # Calculate the new number res_string = str(int(s1) + int(s2)) # Reverse it res_string = res_string[::-1] # Create the new LinkedList dummy = ListNode(-1) prev = dummy for char in res_string: cur = ListNode(int(char)) prev.next = cur prev = cur return dummy.next
@Jambajakumba
@Jambajakumba Жыл бұрын
I went for a similar approach. Simplest to think about. And linear time as well. I would advice to make one long iteration for both l1 and l2, using l1 or l2 not being None. Good job!
@piyusharyaprakash4365
@piyusharyaprakash4365 Жыл бұрын
you don't need to reverse the string if you do it like this s1 = str(cur.val) + s1
@hwang1607
@hwang1607 Жыл бұрын
@@piyusharyaprakash4365 can you explain this
@lifeofme3172
@lifeofme3172 Жыл бұрын
could have reduced these statements within single block, otherwise awesome explanation thank you if(l1 != null){ v1 = l1.val; l1 = l1.next; } if(l2 != null){ v2 = l2.val; l2 = l2.next; }
@infos5319
@infos5319 2 жыл бұрын
Can you explain how can I call the l1 and l2 listnodes in the addtwonumber function to test?
@crosswalker45
@crosswalker45 2 жыл бұрын
it's a bit compicated to explain it in words. I would rather suggest you to watch the videos on how to create linklist object and other related problems ( which aren't directly given into the function like this leetcode problem)
@mugilmithran6955
@mugilmithran6955 2 жыл бұрын
@@crosswalker45 hi, thanks a lot man.
@aumrudhlalkumartj1948
@aumrudhlalkumartj1948 2 жыл бұрын
Thanks
@morenoh149
@morenoh149 Жыл бұрын
its interesting how you build the answer after the dummy node and return the answer. Its not like the test cases can detect the dummy node
@michaelwilliams8986
@michaelwilliams8986 2 ай бұрын
I'm getting memory limit exceeded. Did something change on Leetcode's end?
@guyfieri4605
@guyfieri4605 Жыл бұрын
I don't understand what's going on with carry. Wouldn't always be a left over number there by the time two get to the second digit in the list nodes. First time through: val = 2 + 5 + 0 carry = 7 // 10 Doesn't that leave carry as .7 when we get to the next digits? I'm very confused.
@aiml66_bangerashashankchan81
@aiml66_bangerashashankchan81 Жыл бұрын
In Python, we can perform floor division (also sometimes known as integer division) using the // operator. This operator will divide the first argument by the second and round the result down to the nearest whole number So, 7 // 10 = 0
@badachoi6882
@badachoi6882 2 жыл бұрын
I did 'print(Solution().addTwoNumbers(l1,l2))' and got error "list object has no attribute 'val'... how do I fix it?
@mojajojajo
@mojajojajo 3 жыл бұрын
Why are these things so difficult 😣?
@sanooosai
@sanooosai Жыл бұрын
great thank you
@bilal2.042
@bilal2.042 3 жыл бұрын
thank you for the explaination :)
@yuushamenma2130
@yuushamenma2130 4 жыл бұрын
The only part I don't understand about this, and it's a pretty stupid question is: why do we return dummy.next? I assumed dummy.next would refer only to the next node in the linked list and not the whole list.
@bonfire62292
@bonfire62292 4 жыл бұрын
The reason is because he is modifying the .next node in the array be default, so we're just not modifying the original node. Thus we return the .next node as the "beginning" of the list.
@hariprasadg123
@hariprasadg123 3 жыл бұрын
@@bonfire62292 but where is the dummy.next getting assigned? Initially a dummy node is created and it is assigned to cur. Only cur is being updated right?
@dweebosupremo5904
@dweebosupremo5904 3 жыл бұрын
​@@hariprasadg123 I could be wrong but i think cur and dummy both point at the same object. If you've seen a binary tree inversion problem solution, it's the same reason you would need to create a temp before setting left = right and right = left. I could be wrong though.
@ivanz4932
@ivanz4932 3 жыл бұрын
In the LeetCode compiler, there is some instruction: """ :type l1: ListNode :type l2: ListNode :rtype: ListNode """ This indicates you only need to return the first node of the output. Of course there are some extra codes in the background to initiate two input lists and print the output list, but LeetCode already took care of that. It could look like this: l1 = ListNode(2) l1_2 = ListNode(4) l1_3 = ListNode(3) l2 = ListNode(5) l2_2 = ListNode(6) l2_3 = ListNode(4) l1.next = l1_2 l1_2.next = l1_3 l2.next = l2_2 l2_2.next = l2_3 final1 = Solution().addTwoNumbers(l1,l2) final2 = final1.next final3 = final2.next print [final1.val, final2.val, final3.val]
@bizdep6237
@bizdep6237 3 жыл бұрын
@@ivanz4932 Where do you see the leetcode compiler instructions in the question? I don't find this part where it says that the return type is just one node. But it makes sense now that why the output of the program returns dummy.next. Thanks for explaining this part with much needed details.
@iambdot
@iambdot Жыл бұрын
Stupid question but how does "dummy" get updated when all code changes are done to "cur"?
@chillcoder
@chillcoder Жыл бұрын
Both dummy and cur are both pointers to the same list, but serve different purposes: We are using dummy to point to the start of the list and cur will be used to add additional nodes + move to the latest node in the list.
@heyquantboy
@heyquantboy 4 жыл бұрын
Beginner question- I wanted to build test cases before diving in. I went off on a tangent to construct ListNode instances- which I needed as inputs to LeetCode's provided addTwoNumbers interface. I prepared all my tests before even thinking about the solution. Is this wrong? I don't see anyone doing this. Is this wrong or shouldn't we do TDD?
@mrunfunny
@mrunfunny 3 жыл бұрын
This is a perfectly valid strategy but it's time consuming and hence not popular in CP community.
@yuriish7570
@yuriish7570 Жыл бұрын
I cant figure out how does cur work. If I print id(cur) == id(dummy) it's true, but if i print cur and dummy inside or after while cycle the output is different. Tell me please what's going on or What should I google to clarify that ?
@raviy10
@raviy10 Жыл бұрын
Thank you !!!
@tsunningwah3471
@tsunningwah3471 11 ай бұрын
can anyone tell me why we're returning the dummy.next and not dummy itself? wont we be able to access every other element if we just return dummy?
@alyahmed9925
@alyahmed9925 Жыл бұрын
Can someone explain the dummy listnode and how changing in cur changes dummy?
@neelshah1617
@neelshah1617 2 жыл бұрын
Thank you for a quick solution! However, it is not space optimized as per the requirement: Ignoring the allocation of a new linked list, try to use constant memory when solving it. Would be better to add summation digits in longer LL.
@giggity30
@giggity30 2 жыл бұрын
"I am still unemployed" Not anymore!
@rohanmahajan6333
@rohanmahajan6333 9 ай бұрын
so do we have a first node that is just null in all of these
@sajithraj383
@sajithraj383 2 жыл бұрын
Can Some please explain why the dummy is still getting updated when after the first iteration cur is updated to a different object. newNode = ListNode(columnSum % 10) curr.next = newNode curr = newNode
@robwalsh3858
@robwalsh3858 2 жыл бұрын
At the start of the loop cur = dummy. On the first iteration you are assigning cur.next (aka dummy.next) with the first digit of the solution. So now dummy.next equals the head node of the solution so at the end we return dummy.next. dummy.next will always point to this head node no matter what cur gets changed to.
@ai4sme
@ai4sme 2 жыл бұрын
Hi Sajith, Here a good explanation: stackoverflow.com/questions/58759348/when-does-a-pointer-to-a-linked-list-change-the-actual-list
@drainedzombie2508
@drainedzombie2508 10 ай бұрын
@@ai4sme Thanks for this. TIL python variables are essentially references/pointers to objects i.e. class instances.
@indhumathi5846
@indhumathi5846 Жыл бұрын
understood
@theunderhook9913
@theunderhook9913 2 жыл бұрын
Why can;t we simply reverse two lists first, sum them and then reverse an output?
@minecraftredstoneinspiration
@minecraftredstoneinspiration Жыл бұрын
Why can't you reverse both list and just add the two reversed list together?
@TobiasLange-n5c
@TobiasLange-n5c 3 ай бұрын
Why do you write in the while loop just "l1 or l2 or carry"
Making an Algorithm Faster
30:08
NeetCodeIO
Рет қаралды 151 М.
Reverse Linked List II - Leetcode 92 - Python
16:03
NeetCode
Рет қаралды 86 М.
Hoodie gets wicked makeover! 😲
00:47
Justin Flom
Рет қаралды 139 МЛН
I thought one thing and the truth is something else 😂
00:34
عائلة ابو رعد Abo Raad family
Рет қаралды 9 МЛН
Farmer narrowly escapes tiger attack
00:20
CTV News
Рет қаралды 12 МЛН
The Ultimate Sausage Prank! Watch Their Reactions 😂🌭 #Unexpected
00:17
La La Life Shorts
Рет қаралды 8 МЛН
10 Math Concepts for Programmers
9:32
Fireship
Рет қаралды 1,9 МЛН
NUMBER OF ISLANDS - Leetcode 200 - Python
11:41
NeetCode
Рет қаралды 333 М.
How I would learn Leetcode if I could start over
18:03
NeetCodeIO
Рет қаралды 696 М.
Software Engineering Job Interview - Full Mock Interview
1:14:29
freeCodeCamp.org
Рет қаралды 1,6 МЛН
LeetCode was HARD until I Learned these 15 Patterns
13:00
Ashish Pratap Singh
Рет қаралды 588 М.
Coin Change - Dynamic Programming Bottom Up - Leetcode 322
19:23
Container with Most Water - Leetcode 11 - Python
12:37
NeetCode
Рет қаралды 365 М.
Top K Frequent Elements - Bucket Sort - Leetcode 347 - Python
13:13
How to Solve ANY LeetCode Problem (Step-by-Step)
12:37
Codebagel
Рет қаралды 304 М.
Palindrome Number - Leetcode 9 - Python
12:00
NeetCode
Рет қаралды 78 М.
РАЗВОД С iPHONE ЗА 600.000 @alisherbeisebai #smartphone #айфон
1:01
ТЕХНОБЛОГ АЛИША
Рет қаралды 228 М.
Nokia is built different...☠️
0:39
GoodBoyShaggy
Рет қаралды 21 МЛН
Что делать если разрядился iPad
0:53
Mikha Zen
Рет қаралды 73 М.
Глюк на моем iPhone 16 Pro Max
0:26
ТЕХНОБЛОГ ГУБАРЕВ СЕРГЕЙ
Рет қаралды 1,4 МЛН