我是靠谱客的博主 孤独衬衫,最近开发中收集的这篇文章主要介绍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 #62 二进制求和所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

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

评论列表共有 0 条评论

立即
投稿
返回
顶部