LeetCode --- 数学--- 67.二进制求和

本人看这题的时候脑回路清奇,竟让不由自主的想到了位运算。

通过& 和^ 俩个操作可以快速的计算。且停止计算的条件是 & 的结果为0时候退出,如果不是就一直进行移位 , & 和 ^ 计算。具体原理我也太难描述但是有 官方文档 

 public string AddBinary1(string a, string b)
        {
            var num_a = Convert.ToInt64(a, 2);
            var num_b = Convert.ToInt64(b, 2);
            // 0x 

            var and = num_a & num_b;
            var xor = num_a ^ num_b;
            while (and != 0)
            {
                and = and << 1;
                var tmpand = and & xor;
                xor = xor ^ and;
                and = tmpand;
            }

            return Convert.ToString((and + xor), 2);
        }

但是注意哦 ,这么写会通过不了哦 ,我这里转换成的是int类型但是题目给的是字符串(可能会很长),但是对于取值范围不大的时候可以这么使用 ( ̄▽ ̄)"

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值