이상한 문자 만들기

yejichoi·2023년 3월 8일
0

알고리즘 스터디

목록 보기
21/153
post-thumbnail

이상한 문자 만들기

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

제한 사항

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

입출력 예

sreturn
"try hello world""TrY HeLlO WoRlD"

입출력 예 설명

"try hello world"는 세 단어 "try", "hello", "world"로 구성되어 있습니다. 각 단어의 짝수번째 문자를 대문자로, 홀수번째 문자를 소문자로 바꾸면 "TrY", "HeLlO", "WoRlD"입니다. 따라서 "TrY HeLlO WoRlD" 를 리턴합니다.


나의 풀이

정확성 18.8🥲
알고리즘은 예외처리 싸움인거 같다

function solution(s) {
  let answer =''
  let arr = s.split('')
  console.log(arr)
for(let i = 0; i < arr.length; i++){
  if(i % 2 === 0){ //짝수 인덱스
   answer = answer + arr[i].toUpperCase()
   
  }
  else{
   answer = answer + arr[i].toLowerCase()

  }
}
    return answer
}

정답 풀이

    let answer = '';
    let words = s.split(' '); // 길이 3
    
    for (let i = 0; i < words.length; i++) {
        for(let j = 0; j < words[i].length; j++) { //알파벳에 접근
            if(j % 2 === 0) {
                answer += words[i][j].toUpperCase();
            } else {
                answer += words[i][j].toLowerCase();
            }
        }
        if (i < words.length -1) { //마지막을 제외한 단어 사이에 공백 추가 
            answer += ' ';
        }
    }
    return answer;
}

0개의 댓글