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

การเข้ารหัสสตริงตัวเลขเป็นสตริง 0s และ 1s ใน JavaScript


ปัญหา

เราจำเป็นต้องเขียนฟังก์ชัน JavaScript ที่ใช้สตริงที่แสดงตัวเลขทศนิยม

ฟังก์ชันของเราควรแปลง/เข้ารหัสทศนิยมนี้เป็นเลขฐานสองตามกฎต่อไปนี้

สำหรับแต่ละหลัก d ของ n

  • ให้ k เป็นจำนวนบิตของ d
  • เราเขียน k-1 คูณกับหลัก 0 ตามด้วยหลัก 1
  • เราเขียนเลข d เป็นสตริงไบนารี โดยบิตขวาสุดมีความสำคัญน้อยที่สุด
  • สุดท้าย เราเชื่อมผลลัพธ์ของ b) และ c) เพื่อรับการเข้ารหัสของ d

ในที่สุด เราก็เชื่อมผลลัพธ์ทั้งหมดที่ได้จากตัวเลขของ n

ดังนั้น รหัส 2 เป็น 0110 และ 3 เป็น 0111

ตัวอย่าง

ต่อไปนี้เป็นรหัส -

const str = '77338855';
const encodeNumString = (str = '') => {
   const buildarray = (string = '') => {
      let n = string.split(''), res = '';
      n.forEach(x => {
         let num = Number(x).toString(2);
         num = '0'.repeat(num.length -1) + '1' + num;
         res += num;
      });
      return res;
   }
   const arr = [];
   let res = "";
   for (let i = 0; i < 10; i++){
      arr.push(buildarray(String(i)));
   };
   while (str.length){
      for (let i = 0; i < 10; i++) {
         if (str.startsWith(arr[i])) {
            res += String(i);
            str = str.slice(arr[i].length);
            break;
         }
      }
   }
   return res;
};
console.log(encodeNumString(str));

ผลลัพธ์

ต่อไปนี้เป็นเอาต์พุตคอนโซล -

001111001111011101110001100000011000001101001101