문자열 s는 한 개 이상의 단어로 구성되어 있습니다. 각 단어는 하나 이상의 공백문자로 구분되어 있습니다. 각 단어의 짝수번째 알파벳은 대문자로, 홀수번째 알파벳은 소문자로 바꾼 문자열을 리턴하는 함수, solution을 완성하세요.
s | return |
---|---|
"try hello world" | "TrY HeLlO WoRlD" |
"try hello world"는 세 단어 "try", "hello", "world"로 구성되어 있습니다. 각 단어의 짝수번째 문자를 대문자로, 홀수번째 문자를 소문자로 바꾸면 "TrY", "HeLlO", "WoRlD"입니다. 따라서 "TrY HeLlO WoRlD" 를 리턴합니다.
function solution(s) {
var answer = '';
return answer;
}
//콘솔은 되는데 통과가 되지 않았던
function solution(s) {
var x = s.split(' ');
var answer = '';
for (let i = 0; i < x.length; i++) {
var result = x[i].split('')
answer += result.map((cur, j) => j%2 ? cur.toLowerCase() : cur.toUpperCase()).join('') + " ";
}
return answer.trim();
}
//통과된 코드
function solution(s) {
var x = s.split(' ');
var answer = [];
for (let i = 0; i < x.length; i++) {
answer.push(x[i].split('').map((cur, j) => j%2 ? cur.toLowerCase() : cur.toUpperCase()).join(''));
}
return answer.join(" ");
}
고민도 많이 하고 시간도 많이 썼다. 어떻게 풀지도, 어떤 함수를 쓸지도 다 아는 상황에서 잘 풀리지 않으니 정말 답답했다. 첫 번째 풀이에서는 지인 개발자분 말씀으로는 .join뒤에 space 붙힌 게 아마 몇몇 테스트 케이스에서 걸리지 않았던 것 같다고 하셨다.
이는 내가 answer type을 string과 array로 많이 시도하며 고민했던 요소랑 일맥상통하다. 첫 번째 풀이에서는 string type의 answer에 string +string +.. 이런 식으로 접근했고, 두 번째 풀이에서는 answer array에 push하고 join으로 합쳐버렸다.
잠도 얼마 못 자고 가야했던 수영도 못 갔지만, 그래도 뿌듯하다.
중복
function toWeirdCase(s){
return s.toUpperCase().replace(/(\w)(\w)/g, function(a){return a[0].toUpperCase()+a[1].toLowerCase();})
}
(출처: https://developer.mozilla.org/ko/docs/Web/JavaScript/Guide/Regular_Expressions)