leetcode 67. 二进制求和

  1. 二进制求和
    已解答
    简单
    相关标签
    相关企业
    给你两个二进制字符串 a 和 b ,以二进制字符串的形式返回它们的和。

示例 1:

输入:a = "11", b = "1"

输出:"100"

示例 2:

输入:a = "1010", b = "1011"

输出:"10101"

提示:

1 <= a.length, b.length <= 104

a 和 b 仅由字符 '0' 或 '1' 组成

字符串如果不是 "0" ,就不含前导零

解题思路

将两字符串倒置,依次进行相加,遇到二进位。

cpp 复制代码
class Solution {
public:
    string addBinary(string a, string b) {
        string answer;
        reverse(a.begin(),a.end());
        reverse(b.begin(),b.end());
        int n = max(a.size(),b.size());
        int carry = 0; //进位值
        for(size_t i=0;i<n;i++)
        {
            /*根据当前位置 i 的字符值来更新 carry(进位)
            如果超出字符串的长度填充0,如果没超出等于一就返回1,
            不等于1就是0
            */
            carry += ( i<a.size() ? (a.at(i)=='1') : 0 );
            carry += (i < b.size() ? (b.at(i)=='1') : 0 );
            answer.push_back( (carry % 2) ? '1' : '0');
            carry /=  2; 
            /* carry /=  2; 这一操作更新 carry,决定是否有进位需要带到下一位的计算中。例如,当 carry 为 2 或 3 时,需要产生进位 1,因此 carry /= 2 的结果为 1,即将进位传递给下一位。*/
        }

        if(carry)
        {
            //如果还有进位,插入1.
            answer.push_back('1');
        }
        reverse(answer.begin(),answer.end());//-逆序
        return answer;
    }
};
相关推荐
小尧嵌入式1 分钟前
【Linux开发二】数字反转|除数累加|差分数组|vector插入和访问|小数四舍五入及向上取整|矩阵逆置|基础文件IO|深入文件IO
linux·服务器·开发语言·c++·线性代数·算法·矩阵
one____dream4 分钟前
【算法】大整数数组连续进位
python·算法
one____dream4 分钟前
【算法】合并两个有序链表
数据结构·python·算法·链表
大江东去浪淘尽千古风流人物4 分钟前
【Project Aria】Meta新一代的AR眼镜及其数据集
人工智能·嵌入式硬件·算法·性能优化·ar·dsp开发
电饭叔4 分钟前
has_solution = False 是什么 费马大定律代码化和定理《计算机科学中的数学》外扩学习3
学习·算法
We་ct5 分钟前
LeetCode 238. 除了自身以外数组的乘积|最优解详解(O(n)时间+O(1)空间)
前端·算法·leetcode·typescript
闻缺陷则喜何志丹6 分钟前
【动态规划】P9980 [USACO23DEC] Flight Routes G|普及+
c++·算法·动态规划·洛谷
Σίσυφος19006 分钟前
视觉矩阵之 正交矩阵
人工智能·算法·矩阵
wen__xvn7 分钟前
基础算法集训第21天:Bellman-Ford
算法
zfj3217 分钟前
小数和整数10进制转2进制算法
算法·二进制·进制转换·十进制