문제
숫자 n을 받는 JavaScript 함수를 작성해야 합니다. 우리의 함수는 가능한 가장 짧은 이진 문자열을 이 숫자의 이진 표현의 끝에 연결하여 얻은 해당 숫자의 다음으로 높은 5의 배수를 반환해야 합니다.
예시
다음은 코드입니다 -
const generateAll = (num = 1) => { const res = []; let max = parseInt("1".repeat(num), 2); for(let i = 0; i <= max; i++){ res.push(i.toString(2).padStart(num, '0')); }; return res; }; const smallestMultiple = (num = 1) => { const numBinary = num.toString(2); let i = 1; while(true){ const perm = generateAll(i); const required = perm.find(binary => { return parseInt(numBinary + binary, 2) % 5 === 0; }); if(required){ return parseInt(numBinary + required, 2); }; i++; }; }; console.log(smallestMultiple(8));
출력
35