문제
십진수를 나타내는 문자열을 받는 JavaScript 함수를 작성해야 합니다.
우리 함수는 다음 규칙에 따라 이 십진수를 이진수로 변환/인코딩해야 합니다.
n
의 각 숫자 d에 대해- 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