67. Add Binary
Input: a = "11", b = "1"
Output: "100"Input: a = "1010", b = "1011"
Output: "10101"string addBinary(string a, string b) { // time: O(m + n); space: O(m + n)
int m = a.length(), n = b.length(), carry = 0;
string res;
for (int i = m - 1, j = n - 1; i >= 0 || j >= 0 || carry; --i, --j) {
int tmp = (i >= 0 ? (a[i] - '0') : 0) + (j >= 0 ? (b[j] - '0') : 0) + carry;
carry = tmp / 2;
tmp %= 2;
res += (tmp + '0');
}
reverse(res.begin(), res.end());
return res;
}Last updated