이상한 문자 만들기



  • 문제 설명

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

    제한 사항

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

    입출력 예 설명

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



문제 풀이

  • 공백을 포함한 각 문자를 배열에 저장한다.
  • 공백을 기준으로 분리된 문자열마다 0부터 다시 값을 시작해야하므로 count를 선언, 배열에 공백이 있을 경우는 count를 0으로 초기화
  • count가 짝수인 경우 대문자, 홀수인 경우는 소문자로 변환
  • join을 사용해 문자열 다시 합치기
class Solution {
    public String solution(String s) {
        String answer = "";
				// 1. 문자열의 문자 분리 후 배열에 저장
        String[] str = s.split("");
        int count = 0; // 짝홀수 계산할 변수선언
        
        for (int i = 0; i < s.length(); i++) {
						// 2-1. 공백이 있을 경우 count값 초기화
            if (str[i].equals(" ")) {
                count = 0;
                continue;
            }
						// 2-2. 짝수인 경우 대문자 변환  
            if (count%2 == 0) str[i] = str[i].toUpperCase();
						// 2-3. 홀수인 경우 소문자 변환
            else str[i] = str[i].toLowerCase();
            count ++;
        }
        answer = String.join("", str);
        
        return answer;
    }
}