ปัญหา
เราจำเป็นต้องเขียนฟังก์ชัน 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