Add Binary - Javacript
2016-06-15 06:29
344 查看
Given two binary strings, return their sum (also a binary string).
For example,
a =
b =
Return
Tag
Math, String
----------------------------------------------------------------------------------------------------------------------------------------------------------------------------
/**
* @param {string} a
* @param {string} b
* @return {string}
*/
var addBinary = function(a, b) {
var ret = "";
var len1 = a.length;
var len2 = b.length;
if(len1 === 0 && len2 === 0) {
return ret;
} else if(len1 === 0) {
return b;
} else if(len2 === 0) {
return a;
} else {
if(len1<len2) {
for(var i=0;i<len2-len1;i++) {
a = '0' + a;
}
} else if(len1>len2) {
for(i=0;i<len1-len2;i++) {
b = '0' + b;
}
}
// guarantee that a and b are the same length
var len = a.length;
var carry = 0;
for(i=len-1;i>=0;i--) {
var sum = parseInt(a[i]) + parseInt(b[i]) + carry;
if(sum >= 2) {
carry = 1;
sum = sum % 2;
} else {
carry = 0;
}
ret = sum + ret;
}
if(carry === 1) {
ret = carry + ret;
}
return ret;
}
};
For example,
a =
"11"
b =
"1"
Return
"100".
Tag
Math, String
----------------------------------------------------------------------------------------------------------------------------------------------------------------------------
/**
* @param {string} a
* @param {string} b
* @return {string}
*/
var addBinary = function(a, b) {
var ret = "";
var len1 = a.length;
var len2 = b.length;
if(len1 === 0 && len2 === 0) {
return ret;
} else if(len1 === 0) {
return b;
} else if(len2 === 0) {
return a;
} else {
if(len1<len2) {
for(var i=0;i<len2-len1;i++) {
a = '0' + a;
}
} else if(len1>len2) {
for(i=0;i<len1-len2;i++) {
b = '0' + b;
}
}
// guarantee that a and b are the same length
var len = a.length;
var carry = 0;
for(i=len-1;i>=0;i--) {
var sum = parseInt(a[i]) + parseInt(b[i]) + carry;
if(sum >= 2) {
carry = 1;
sum = sum % 2;
} else {
carry = 0;
}
ret = sum + ret;
}
if(carry === 1) {
ret = carry + ret;
}
return ret;
}
};
相关文章推荐
- JQuery1——基础($对象,选择器,对象转换)
- Android之获取手机上的图片和视频缩略图thumbnails
- Android学习笔记(二九):嵌入浏览器
- android string.xml文件中的整型和string型代替
- Android java 与 javascript互访(相互调用)的方法例子
- JavaScript演示排序算法
- javascript实现10进制转为N进制数
- android上改变listView的选中颜色
- String.intern
- 最后一次说说闭包
- Ajax
- 2019年开发人员应该学习的8个JavaScript框架
- HTML中的script标签研究
- 对一个分号引发的错误研究
- 异步流程控制:7 行代码学会 co 模块
- ES6 走马观花(ECMAScript2015 新特性)
- JavaScript拆分字符串时产生空字符的原因