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