Front-End

vsoghlv@naver.com

알고리즘 이상한 문자 만들기

문제 설명

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

제한사항

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

입출력 예

s return
try hello world TrY HeLlO WoRlD

문제풀이

function solution(s) {
    var answer = s.toLowerCase().split("");
    let count = 2;
    for(let i in answer){
        if(count % 2===0){
            answer[i] = answer[i].toUpperCase();
        }       
            count++
        if(answer[i]===" ") count = 2;
    }
    return answer.join("");
}

먼저 받은 문자열을 하나하나 잘라서 배열로 만들어준다. 이후 배열만큼 반복문을 돌며 카운트(현재 인덱스를 세기 위함) 를 이용, 카운트가 짝수이면 배열의 [i] 를 대문자로 아니면 그냥 둔다. 이때 answer[i]가 공백이면 count 를 다시 2로 설정해줌으로써 공백은 무시하고 단어별로 기준이 되도록 한다.