Leetcode 67.二进制求和【C++】
本文最后更新于:2022年3月23日 晚上
题目
给定两个二进制字符串,返回他们的和(用二进制表示)。
输入为非空字符串且只包含数字 1 和 0。
示例 1:
输入: a = "11", b = "1"
输出: "100"
示例 2:
输入: a = "1010", b = "1011"
输出: "10101"
解题思路
这个题不可避免的要处理十进制和二进制之间的转换问题,按照二进制求和的方法,从低位到高位依次相加。
定义一个 car 记录进位,默认为 0 即没有进位,有进位只可能为 1 ;定义一个 string 类型的 sum 用以保存得到的和;定义两个int型变量 cur_a 和 cur_b 保存两个字符串相同位置上的字符转为 int 型后的值,方便进行常规加法计算,若字符串为空则作 0 处理,效果等同于没有数与之相加;x 保存某一位上的相加结果,以根据其相加的结果进行进位处理。
因为是二进制加法,x 可能的取值情况仅四种:
//前两个数为同一位上的两个数,最后一个数即进位
0 + 0 + 0 = 0
0 + 1 + 0 = 1
1 + 0 + 0 = 1
1 + 1 + 0 = 2
0 + 0 + 1 = 1
0 + 1 + 1 = 2
1 + 0 + 1 = 2
1 + 1 + 1 = 3
当 x 为 0 或 1 时,不需要进位(car为0),x 保持;当 x>1 时,即相加结果为 2 或 3 时,需要进位处理(car为1),为 2 时 x 进 1 取 0,为 3 时 x 进 1 取 1。将整型 x 转为字符串加到 sum 的开头,并将 a、b 字符串的尾字符删去,循环重复上述步骤即可,直到字符串 a、b 均为空并且进位为 0。
代码
class Solution {
public:
string addBinary(string a, string b) {
int car = 0;//进位
string sum = "";//返回值
while (a.length() > 0 || b.length() > 0 || car == 1) {
int cur_a = a.length() == 0 ? 0 : a[a.length() - 1] - 48;//末尾字符转为整型,如果为空则为0
int cur_b = b.length() == 0 ? 0 : b[b.length() - 1] - 48;
int x = cur_a + cur_b + car;//两末尾字符以及进位相加,x的可能取值有0,1,2,3
car = x > 1 ? 1 : 0;//如果x>1说明有进位,置car为1
if (x > 1) //x>1需要进位处理
x = x > 2 ? 1 : 0;//只可能是2或3,2进1留0,3进1留1
sum = to_string(x) + sum;//将x加到字符串头部
if (a.length() > 0)
a.pop_back();//删除已处理的尾字符
if (b.length() > 0)
b.pop_back();
}
return sum;
}
};
Leetcode 67.二进制求和【C++】
https://mxy493.xyz/202003076204/