개발 공부/알고리즘

[프로그래머스 알고리즘] "이상한 문자 만들기" JavaScript / .map()

U_D 2022. 3. 15. 11:37

1. 문제 설명

문자열 s는 한 개 이상의 단어로 구성되어 있습니다. 각 단어는 하나 이상의 공백문자로 구분되어 있습니다. 각 단어의 짝수번째 알파벳은 대문자로, 홀수번째 알파벳은 소문자로 바꾼 문자열을 리턴하는 함수, solution을 완성하세요.

 

 

 

2. 제한 조건

문자열 전체의 짝/홀수 인덱스가 아니라, 단어(공백을 기준)별로 짝/홀수 인덱스를 판단해야합니다.
첫 번째 글자는 0번째 인덱스로 보아 짝수번째 알파벳으로 처리해야 합니다.

 

 

 

 

3. 예시

입력/출력

 

4. 풀이

[for 활용]

일단 문제 푸는데는 실패했는데.. 좋은 답들을 붙여 본다.

function solution(s) {
    let result = ''; 
    let count = 0; 
    for (let i = 0; i < s.length; i++) 
    { result += count % 2 === 0 ? s[i].toUpperCase() : s[i].toLowerCase(); 
     count = s[i] === ' ' ? 0 : ++count; 
    } 
    return result;
}

 

[map 2회 활용]

function toWeirdCase(s) {
  return s.split(' ').map((a) => {
    return a.split('').map((b, i) => {
      return (i % 2 === 0) ? b.toUpperCase() : b.toLowerCase();
    }).join('');
  }).join(' ');
}

 

[map 1회 활용]

function solution(s) {
    return s.split(' ').map(str => {
        let result = '';
        for(let i = 0; i < str.length; i++) {
            if(i%2!=0) {
                result += str[i].toLowerCase();
            } else {
                result += str[i].toUpperCase();
            }
        }
        return result;
    }).join(' ');
}