前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >二进制求和

二进制求和

作者头像
WindrunnerMax
发布2020-08-27 10:56:55
5120
发布2020-08-27 10:56:55
举报
文章被收录于专栏:Czy‘s BlogCzy‘s Blog

二进制求和

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

示例

代码语言:javascript
复制
输入: a = "11", b = "1"
输出: "100"
代码语言:javascript
复制
输入: a = "1010", b = "1011"
输出: "10101"

提示

  • 每个字符串仅由字符'0''1'组成。
  • 1 <= a.length, b.length <= 10^4
  • 字符串如果不是"0",就都不含前导零。

题解

代码语言:javascript
复制
/**
 * @param {string} a
 * @param {string} b
 * @return {string}
 */
var addBinary = function(a, b) {
    var longer = "";
    var shorter = "";
    if(a.length > b.length){
        longer = a;
        shorter = b.padStart(a.length,0);
    }else{
        longer = a.padStart(b.length,0);
        shorter = b;
    }
    var target = "";
    var addition = 0;
    for(let i=longer.length-1;i>=0;--i){
        let unitNum = ~~(longer[i]) + ~~(shorter[i]) + addition;
        addition = 0;
        if(unitNum >= 2) {
            addition = 1;
            target = `${unitNum-2}${target}`;
        }else{
            target = `${unitNum}${target}`;
        }
    }
    if(addition) target = `1${target}`;
    return target;
};

思路

首先需要将两个字符串的长度进行统一,判断两个字符串长度的长度,然后选出短的字符串在字符串前填充0,也就是使用String.prototype.padStart()方法进行填充,然后定义目标字符串以及进位标记变量,然后从后开始往前遍历字符串,将字符串中的字符转换成数字类型然后相加并与进位变量相加,其中~~就是利用位运算将字符转换成数字,相加完成后将进位标志置为0,然后判断字符是否大于2,如果大于等于2则将相加的字符减掉2并将进位标记记为1,若小于2则直接拼接字符串,然后不断循环完成目标字符的拼接,若最后依然有进位标志,则直接拼接1到目标字符串前,然后返回目标字符串即可。

每日一题

代码语言:javascript
复制
https://github.com/WindrunnerMax/EveryDay

题源

代码语言:javascript
复制
https://leetcode-cn.com/problems/add-binary
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-06-23 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 二进制求和
    • 示例
      • 提示
        • 题解
          • 思路
            • 每日一题
              • 题源
              领券
              问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档