프로그래머스 레벨 1 - 이상한 문자 만들기

dev-mage·2022년 11월 18일
0

알고리즘 문제 풀이

목록 보기
12/12
post-thumbnail

코딩테스트 연습 - 이상한 문자 만들기

문제 설명

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

제한 사항

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

입출력 예

sreturn
"try hello world""TrY HeLlO WoRlD"

입출력 예 설명

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


풀이

class Solution {
  public String solution(String s) {
        String answer = "";
        String[] strArr = s.split(" ", -1);
        StringBuilder sb = new StringBuilder();
      
        for(int i = 0; i < strArr.length; i++) {
            String word = strArr[i];
            if(word.equals("") && i != strArr.length - 1) {
                sb.append(" ");
            } else {
                for(int j = 0; j < word.length(); j++) {
                    char tempChar = word.charAt(j);
                    if(j % 2 == 0) {
                        sb.append(Character.toUpperCase(tempChar));
                    } else {
                        sb.append(Character.toLowerCase(tempChar));
                    }
                }
                if(i != strArr.length - 1) {
                    sb.append(" ");
                }
            }
        }

        answer = sb.toString();
        return answer;
    }
}

0개의 댓글