[Level1] 이상한 문자 만들기

JMinkyoung·2021년 4월 17일
0

Programmers

목록 보기
22/32

문제

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

제한 조건

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


    입출력 예
sreturn
"try hello world""TrY HeLlO WoRlD"

문제 풀이

주어진 문자열 s를 먼저 공백을 기준으로 잘라준 뒤 임의의 배열에 넣어주었다. 그리곤 해당 배열을 돌면서 각 단어의 index를 기준으로 홀짝을 판별하여 짝수일 경우 j%2===0 에는 대문자로 홀수일 경우 소문자로 바꿔 준 후 그대로 answer 문자열에 추가 해 주었다. 한 단어를 다 검사한 후 뒤에 공백을 추가 해주었다. 하지만 이렇게 구현할 경우 마지막 단어 뒤에도 공백이 생기기 때문에 return 을 할때 맨 뒤 공백을 제거해주었다.

정답 코드 (내 풀이)

function solution(s) {
    let answer = '';
    let temp = '';
    let arr = s.split(' ');
    
    for(let i in arr){
        temp = arr[i];
        for(let j=0; j<temp.length; j++){
            if(j%2===0){
                answer+= temp[j].toUpperCase();
            }else{
                answer+= temp[j].toLowerCase();
            }
        }answer+=" ";
    }
    return answer.slice(0,-1);
}
profile
Frontend Developer

0개의 댓글