Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> Javascript

การเพิ่มสตริงไบนารีเข้าด้วยกัน JavaScript


เราจำเป็นต้องเขียนฟังก์ชัน JavaScript ที่ใช้สตริงไบนารีสองสตริง ฟังก์ชันควรส่งคืนผลรวมของสตริงไบนารีสองตัวนั้นเป็นสตริงไบนารีอื่น

ตัวอย่างเช่น −

หากทั้งสองสตริงคือ −

const str1 = "1010";
const str2 = "1011";

จากนั้นผลลัพธ์ควรเป็น −

const output = '10101';

ตัวอย่าง

const str1 = "1010";
const str2 = "1011";
const addBinary = (str1, str2) => {
   let carry = 0;
   const res = [];
   let l1 = str1.length, l2 = str2.length;
   for (let i = l1 - 1, j = l2 - 1; 0 <= i || 0 <= j; --i, --j) {
      let a = 0 <= i ? Number(str1[i]) : 0,
      b = 0 <= j ? Number(str2[j]) : 0;
      res.push((a + b + carry) % 2);
      carry = 1 < a + b + carry;
   };
   if (carry){
      res.push(1);
   }
   return res.reverse().join('');
};
console.log(addBinary(str1, str2));

ผลลัพธ์

และผลลัพธ์ในคอนโซลจะเป็น −

10101