您的位置:首页 > 其它

lintcode-408-二进制求和

2017-08-14 09:14 295 查看

408-二进制求和


给定两个二进制字符串,返回他们的和(用二进制表示)。

样例

a = 11

b = 1

返回 100

标签

二进制 字符串处理 脸书


思路

先相加,在处理进位,为了方便操作,将选字符串翻转,使低位位于数组前端

code

class Solution {
public:

/*
* @param a: a number
* @param b: a number
* @return: the result
*/
string addBinary(string a, string b) {
// write your code here
int sizeA = a.size(), sizeB = b.size();
if (sizeA <= 0 || sizeB <= 0) {
return string();
}
reversalString(a);
reversalString(b);
string result;
int i = 0, carry = 0;
for (i = 0; i<sizeA && i<sizeB; i++) {
result += '0' + (a[i] - '0' + b[i] - '0');
}
for (; i < sizeA; i++) {
result += a[i];
}
for (; i < sizeB; i++) {
result += b[i];
}
for (i = 0; i < result.size(); i++) {
int temp = result[i] - '0' + carry;
if (temp == 2) {
carry = 1;
result[i] = '0';
}
else if (temp == 3) {
carry = 1;
result[i] = '1';
}
else {
carry = 0;
result[i] = temp + '0';
}
}
if (carry == 1) {
result += '1';
}
reversalString(result);
return result;
}

void reversalString(string &str) {
for (int i = 0; i < str.size() / 2; i++) {
swap(str[i], str[str.size() - 1 - i]);
}
}
};
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: