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])