leetcode 67 : 二进制求和

题目

算法思想 :首先题目给的是字符串,我们采用char-'0'得到数字,得出结果后+'0'转换成字符。其次通过转换使得a是较长的字符串,然后第一次循环加完b的长度,我们可以采用^ 异或操作得到加后的结果,用(a[i]+b[i])/2表示进位数,第二次循环得到剩余a的结果。

 

string addBinary(string a, string b) {
    if(a.length() == 0)
        return b;
    if(b.length() == 0)
        return a;
    string tmp = "";
    if(a.length() < b.length())
    {
        tmp = a;
        a = b;
        b = tmp;
    }
    int i = a.length()-1,j = b.length()-1;
    int a_int,b_int,c = 0;
    while(i >= 0 && j >= 0)
    {
        a_int = a[i]-'0';
        b_int = b[j]-'0'; 
        a[i] = ( (a_int ^ b_int) ^ c) + '0';
        c = (a_int + b_int + c )/2;
        i--;
        j--;
    }
    while(i >= 0)
    {
        a_int = a[i]-'0';
        a[i] = a_int ^ c + '0';
        c = (a_int + c)/2;
        i--;
    }
    if(c != 0)
        a = "1" + a;
    return a;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值