문제

  • 각 소문자는 대문자로, 각 대문자는 소문자로 반환한다.

풀이 01

function alternatingCase(str) {
  let result = '';

  for (let i = 0; i < str.length; i++) {
    if (str[i] === str[i].toUpperCase()) {
      result += str[i].toLowerCase();
    } else {
      result += str[i].toUpperCase();
    }
  }
  return result;
}

alternatingCase('abcd');      // ABCD
alternatingCase('ABCD');      // abcd
alternatingCase('cODeWarS');  // CodEwARs
  • toUpperCase(): 문자열을 대문자로 변환한다.
  • toLowerCase(): 문자열을 소문자로 변환한다.

풀이 02

function alternatingCase(str) {
  return str.split('').map(i => i === i.toUpperCase() ? i.toLowerCase() : i.toUpperCase()).join('');
}

alternatingCase('abcd');      // ABCD
alternatingCase('ABCD');      // abcd
alternatingCase('cODeWarS');  // CodEwARs
  • split(): 문자열을 부분 문자열로 분할하고, 새 배열로 반환한다.
  • map(): 배열 내 모든 element에 대해, 호출한 함수의 결과를 모아 새 배열로 반환한다.
  • join(): 배열의 모든 element를 결합하고, 새 문자열로 반환한다.

풀이 03

function alternatingCase(str) {
  return str.replace(/[a-z]gi, i => /[a-z]/.test(i) ? i.toUpperCase() : i.toLowerCase());
}

alternatingCase('abcd');      // ABCD
alternatingCase('ABCD');      // abcd
alternatingCase('cODeWarS');  // CodEwARs

정규표현식 (RegExp)

  • replace(): 대응되는 문자열을 찾아 다른 문자열로 치환한다.
  • g: 전역 검색
  • i: 대소문자 구분 없는 검색
  • test(): 대응되는 문자열이 있는지 검색하고, true/false를 반환한다.