我是靠谱客的博主 孤独衬衫,这篇文章主要介绍LeetCode #62 二进制求和,现在分享给大家,希望可以做个参考。

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) {
string str = "";
int aa = a.size() - 1,bb = b.size() - 1;
int fz = 0;
int maxn = max(aa,bb);
while(1){
fz += aa < 0 ? 0 : a[aa] - '0';
fz += bb < 0 ? 0 : b[bb] - '0';
str += (fz%2 + '0');
fz /= 2;
aa--,bb--;
if(aa < 0 && bb < 0) break;
}
if(fz) str += '1';
reverse(str.begin(),str.end());
return str;
}
};

 

最后

以上就是孤独衬衫最近收集整理的关于LeetCode #62 二进制求和的全部内容,更多相关LeetCode内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(122)

评论列表共有 0 条评论

立即
投稿
返回
顶部