LeetCode 2 两数相加(链表)
2018-11-05 23:15
459 查看
题目要求:
给定两个非空链表来表示两个非负整数。位数按照逆序方式存储,它们的每个节点只存储单个数字。将两数相加返回一个新的链表。
你可以假设除了数字 0 之外,这两个数字都不会以零开头。
示例:
[code]输入:(2 -> 4 -> 3) + (5 -> 6 -> 4) 输出:7 -> 0 -> 8 原因:342 + 465 = 807
C++代码:
[code]/** * Definition for singly-linked list. * struct ListNode { * int val; * ListNode *next; * ListNode(int x) : val(x), next(NULL) {} * }; */ class Solution { public: ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) { ListNode *result = new ListNode(0); ListNode *tmp = result; int sum = 0; while(l1 || l2){ if(l1){ sum += l1 -> val; l1 = l1 -> next; } if(l2){ sum += l2 -> val; l2 = l2 -> next; } tmp -> next = new ListNode(sum % 10); sum /= 10; tmp = tmp -> next; } if(sum){ tmp -> next = new ListNode(1); } return result -> next; } };
结果:
解析:
方法是直接让每个数相同的位直接相加,当做链表一个节点,比如示例,直接2和5相加,4和6相加,3和4相加,但是有一个问题,这么求出来是
7->10->7,很明显是错误的。
所以就需要用到进位。
第二个需要考虑的问题为循环结束条件,任意一个链表不为空都需要往后走,同时当最后一个数相加大于10时,最后两个节点应为
->0->1,因此结束条件是两链表同时指向结尾空指针,且不需要进位。
方法二:
简洁的写法,速度快了一些
C++代码:
[code]/** * Definition for singly-linked list. * struct ListNode { * int val; * ListNode *next; * ListNode(int x) : val(x), next(NULL) {} * }; */ class Solution { public: ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) { ListNode preHead(0), *p = &preHead; int extra = 0; while (l1 || l2 || extra) { int sum = (l1 ? l1->val : 0) + (l2 ? l2->val : 0) + extra; extra = sum / 10; p->next = new ListNode(sum % 10); p = p->next; l1 = l1 ? l1->next : l1; l2 = l2 ? l2->next : l2; } return preHead.next; } };
结果:
解析:
分析:这里主要有两个问题,一个是两个链表长度不一致时的处理,一个是相加>10时的数据处理。
- 参考解法中运用三目运算符,很好地解决了第一个问题。即长度不一致时,比较短的那个链表用空来表示,数据为0。
- 进位和结果位,分别用/和%运算得到。
阅读更多
相关文章推荐
- Leetcode 第二题,两数链表相加
- 链表:链表两数相加( LeetCode 2. Add Two Numbers(两数相加))
- Leetcode002--单链表两数相加
- LeetCode 02. 两数相加(链表) 03.最大不重复的字符串
- 【LeetCode】- Two Sum(两数相加)
- 刷LeetCode(1)——两数相加
- LeetCode 2. Add Two Numbers(两数相加)
- LeetCode - 66/67 - 两数相加加法模拟
- LeetCode2——Add Two Numbers(两个链表中的数字相加,形成新链表)
- 链表:两数相加
- [LeetCode]2. Add Two Numbers用链表逆序存储的两个数相加
- Leetcode-java实现-002(链表相加)
- LeetCode 2. 两数相加
- [LeetCode] Add Two Numbers 两数相加
- LeetCode Add Two Numbers两个链表数值相加
- [leetcode]两数相加
- [LeetCode]371.Sum of Two Integers两数相加
- 【LeetCode】2. 两数相加(Add Two Numbers,28.6%,中等)
- [leetcode] 2. Add Two Numbers(链表、大数相加)
- leetcode之链表类之链表归并类-----OJ 2/21/23/445 链表相加求和 链表归并