概述
题目描述
解题思路
本题的核心解题思路和字符串相加、两数相加等题目高度类似,都是给出一个字符串,求字符串的和,我们可以从字符串的最后一个字符算起,将一个字符转换为一个数字可以通过减字符0来实现。只要下标大于等于0或者进位不等于0,就进入循环。如果临时和对2取余为0,res则unshift(0),反之unshift(1)。然后根据sum和2的关系,修改进位的值,最后下标减一。
var addBinary = function(a, b) {
let l = a.length - 1;
let r = b.length - 1;
let carry = 0;
let res = [];
while (l >= 0 || r >= 0 || carry != 0) {
let c1 = l >= 0 ? a[l] - '0' : 0;
let c2 = r >= 0 ? b[r] - '0' : 0;
let sum = c1 + c2 + carry;
if (sum % 2) {
res.unshift(1);
} else {
res.unshift(0);
}
if (sum > 2) {
carry = (sum % 2 != 0) ? 1 : 0;
} else if (sum > 0) {
carry = (sum % 2 != 0) ? 0 : 1;
} else {
carry = 0;
}
l--;
r--;
}
return res.join('');
};
题目反思
在刷题的时候,最重要的不是题目的数量,当然题目的数量是很重要的,总结不同的题目,得到这些题目的通用解法,是刷题的核心,就像这道题目,和字符串相加、两数相加都可以使用一样的思路来进行解题。
最后
以上就是现代花生为你收集整理的LeetCode——二进制求和(字符串求和法)的全部内容,希望文章能够帮你解决LeetCode——二进制求和(字符串求和法)所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复