&LeetCode67& 二进制求和

题目

给定两个二进制字符串,返回他们的和(用二进制表示)。
输入为非空字符串且只包含数字 1 和 0。

示例 1:
输入: a = “11”, b = “1”
输出: “100”

来源:力扣(LeetCode

思路

此处二进制数相加,保存在string中,
如何将string和int之间互相转换?
首先,对应位相加时,会涉及进位的可能;
其次,两个输入string的长度也可能会不同,这时我们需要新建一个string,其长度为两条源string中的较大的那个长度值,且将较短的那个输入string通过在开头加字符‘0’来补至较大的那个长度。
最后,逐个从两个string的末尾开始取字符,然后转为数字,相加如果大于等于2,则标记进位标志carry,并且给新string加入一个字符‘0’。

注意:因为ASCII字符中的数字(‘123456’)想转换为纯数字(1,2,3,4…)就要减去48(ASCII单位),而‘0’的ASCII单位正好等于48。

C++代码

class Solution {
public:
    string addBinary(string a, string b) 
    {
        string res;
        int as = a.size();
        int bs = b.size();
        int mn = max(as, bs);
        bool carry = false;
        if (as > bs) 
        {
            for (int i = 0; i < as - bs; ++i) 
            {
                b.insert(b.begin(), '0');
            }
        }
        else if (as < bs) 
        {
            for (int i = 0; i < bs - as; ++i) 
            {
                a.insert(a.begin(), '0');
            }
        }
        for (int i = mn - 1; i >= 0; --i) 
        {
            int tmp = 0;
            if (carry) 
            {
                tmp = (a[i] - '0') + (b[i] - '0') + 1;
            }
            else 
            {
                tmp = (a[i] - '0') + (b[i] - '0');
            }
            if (tmp == 0) 
            {
                res.insert(res.begin(), '0');
                carry = false;
            }
            else if (tmp == 1) 
            {
                res.insert(res.begin(), '1');
                carry = false;
            }
            else if (tmp == 2) 
            {
                res.insert(res.begin(), '0');
                carry = true;
            }
            else if (tmp == 3) 
            {
                res.insert(res.begin(), '1');
                carry = true;
            }
        }
        if (carry) 
        {
        	res.insert(res.begin(), '1');
        }
        return res;
    }
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值