fakeBinary.js (8kyu 26)
Codewars 알고리즘 풀이
Problem
- Given a string of digits, you should replace any digit below 5 with
0
and any digit 5 and above with 1.- 주어진 숫자 문자열에서, 5 미만의 수를 0으로, 5 이상의 수를 1로 반환한다.
Solution 01
function fakeBinary(x) {
let result = '';
for (let i = 0; i < x.length; i++) {
if (Number(x[i]) < 5) {
result += '0';
} else {
result += '1';
}
}
return result;
}
fakeBinary('0123456789'); // 0000011111
fakeBinary('4801635297'); // 0100101011
Solution 02
function fakeBinary(x) {
return x.split('').map(i => i < 5 ? 0 : 1).join('');
}
fakeBinary('0123456789'); // 0000011111
fakeBinary('4801635297'); // 0100101011
split()
메소드문자열을 부분 문자열로 분할하고, 새 배열로 반환한다.
map()
메소드배열 내 모든 element에 대해, 호출한 함수의 결과를 모아 새 배열로 반환한다.
join()
메소드배열의 모든 element를 결합하고, 새 문자열로 반환한다.
Solution 03
function fakeBinary(x) {
return x.replace(/[1-4]/g, '0').replace(/[5-9]/g, '1');
}
fakeBinary('0123456789'); // 0000011111
fakeBinary('4801635297'); // 0100101011
정규표현식 (RegExp)
replace()
: 대응되는 문자열을 찾아 다른 문자열로 치환한다.
g
: 전역 검색
Solution 04
function fakeBinary(x) {
return x.replace(/\d/g, i => i < 5 ? 0 : 1);
}
fakeBinary('0123456789'); // 0000011111
fakeBinary('4801635297'); // 0100101011
정규표현식 (RegExp)
\d
: 숫자에 대응 (=[0-9]
)