문제

문자열 code가 주어집니다. code를 앞에서부터 읽으면서 만약 문자가 “1”이면 mode를 바꿉니다. mode에 따라 code를 읽어가면서 문자열 ret을 만들어냅니다.

mode는 0과 1이 있으며, idx를 0 부터 code의 길이 - 1 까지 1씩 키워나가면서 code[idx]의 값에 따라 다음과 같이 행동합니다.

  • mode가 0일 때
    • code[idx]가 “1”이 아니면 idx가 짝수일 때만 ret의 맨 뒤에 code[idx]를 추가합니다.
    • code[idx]가 “1”이면 mode를 0에서 1로 바꿉니다.
  • mode가 1일 때 - code[idx]가 “1”이 아니면 idx가 홀수일 때만 ret의 맨 뒤에 code[idx]를 추가합니다. - code[idx]가 “1”이면 mode를 1에서 0으로 바꿉니다. 문자열 code를 통해 만들어진 문자열 ret를 return 하는 solution 함수를 완성해 주세요.

단, 시작할 때 mode는 0이며, return 하려는 ret가 만약 빈 문자열이라면 대신 “EMPTY”를 return 합니다.

제한사항

  • 1 ≤ code의 길이 ≤ 100,000
    • code는 알파벳 소문자 또는 “1”로 이루어진 문자열입니다.

입출력 예

code result
“abc1abc1abc” “acbac”

입출력 예 설명

입출력 예 #1

  • code의 각 인덱스 i에 따라 다음과 같이 moderet가 변합니다.

    i code[i] mode ret
    0 “a” 0 “a”
    1 “b” 0 “a”
    2 “c” 0 “ac”
    3 “1” 1 “ac”
    4 “a” 1 “ac”
    5 “b” 1 “acb”
    6 “c” 1 “acb”
    7 “1” 0 “acb”
    8 “a” 0 “acba”
    9 “b” 0 “acba”
    10 “c” 0 “acbac”

따라서 “acbac”를 return 합니다.

코드

function solution(code) {
  // (1)
  var mode = 0;
  var answer = '';
  // (2)
  for (idx = 0; idx < code.length; idx++) {
    // (3)
    if (code[idx] === '1') mode === 0 ? (mode = 1) : (mode = 0);
    // (4)
    if (mode === 0) code[idx] !== '1' && idx % 2 === 0 && (answer += code[idx]);
    // (5)
    else code[idx] !== '1' && idx % 2 !== 0 && (answer += code[idx]);
  }
  // (6)
  return answer === '' ? 'EMPTY' : answer;
}

코드 해설

(1) mode 변수를 0으로 초기화하고 answer 변수를 빈 문자열로 초기화한다.

(2) 입력된 코드의 각 문자에 대해 반복한다.

(3)

  • 현재 문자가 ‘1’인지 확인하고, 해당이 되면, 삼항연산자를 이용한다.
  • mode값이 0이면 mode 값을 0과 1 사이에서 토글한다.

(4)

  • mode를 확인하고 문자를 answer에 추가한다.
  • 만약 mode가 0이면, 문자가 ‘1’이 아니고 짝수 인덱스일 때 answer에 추가한다.

(5) 만약 mode가 1이면, 문자가 ‘1’이 아니고 홀수 인덱스일 때 answer에 추가한다.

(6)

  • answer가 여전히 빈 문자열인지 확인하고, 빈 문자열이면 ‘EMPTY’를 반환하고
  • 그러지 않으면 answer값을 반환한다.