alternatingCase.js (8kyu 31)

Codewars 알고리즘 풀이


Problem

  • Each lowercase letter becomes uppercase, each uppercase letter becomes lowercase.
    • 각 소문자는 대문자로, 각 대문자는 소문자로 반환한다.


Solution 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() 메소드

문자열을 소문자로 변환한다.


Solution 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를 결합하고, 새 문자열로 반환한다.


Solution 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를 반환한다.