Leetcode 面试题 02.05. 链表求和
问题描述
给定两个用链表表示的整数,每个节点包含一个数位。
这些数位是反向存放的,也就是个位排在链表首部。
编写函数对这两个整数求和,并用链表形式返回结果。
示例:
输入:(7 -> 1 -> 6) + (5 -> 9 -> 2),即617 + 295
输出:2 -> 1 -> 9,即912
进阶:假设这些数位是正向存放的,请再做一遍。
示例:
输入:(6 -> 1 -> 7) + (2 -> 9 -> 5),即617 + 295
输出:9 -> 1 -> 2,即912
解题报告
具体见代码,注意链表中两数相加的细节问题:
- 设置一个
哨兵
while
循环的判断条件
实现代码
/**
* 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 *head = new ListNode(-1), *p1 = l1, *p2 = l2, *p = head;//用带头节点的可以少一点初始的特判
int sum = 0, carr = 0;
while (p1 || p2 || carr) //如果改用&&则while结束还要多一些特判
{
sum = 0;//当前两位数字和
if(p1)
{
sum += (p1->val);
p1 = p1->next;
}
if(p2)
{
sum += (p2->val);
p2 = p2->next;
}
sum += carr; //加上上一位的进位
ListNode *t = new ListNode(sum % 10); //得到当前位数字
carr = sum / 10; //得到当前位对下一位的进位
p->next = t;//当前位连接上去
p = p->next;//游标指针更新
}
return head->next;
}
};
// 作者:wu-yu-61
// 链接:https://leetcode-cn.com/problems/sum-lists-lcci/solution/clian-biao-mo-ni-shou-gong-qiu-he-jian-dan-yi-dong/
// 来源:力扣(LeetCode)
// 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
Leetcode 67. 二进制求和
问题描述
给你两个二进制字符串,返回它们的和(用二进制表示)。
输入为 非空 字符串且只包含数字 1 和 0。
示例 1:
输入: a = “11”, b = “1”
输出: “100”
示例 2:
输入: a = “1010”, b = “1011”
输出: “10101”
提示:
每个字符串仅由字符 ‘0’ 或 ‘1’ 组成。
1 <= a.length, b.length <= 10^4
字符串如果不是 “0” ,就都不含前导零。
解题报告
与上一题的解法大差不差的。
实现代码
class Solution {
public:
string addBinary(string a, string b) {
int a1=a.size(), b1=b.size(), i=a1-1, j=b1-1, carry=0,sum;
string ans = "";
while(i>=0||j>=0||carry>0){
sum=0;
if(i>=0)sum+=(a[i--]-'0');
if(j>=0)sum+=(b[j--]-'0');
sum+=carry;
ans.push_back(sum%2?'1':'0');
carry=sum/2;
}
reverse(ans.begin(), ans.end());
return ans;
}
};
参考资料
[1] Leetcode 面试题 02.05. 链表求和
[2] Leetcode 面试题 02.05 题解区:wu-yu-61
[3] Leetcode 67. 二进制求和