본문 바로가기

알고리즘 문제풀이(JAVA)

알고리즘 문제풀이-이상한 문자 만들기(JAVA)

문제 설명

 

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

 

class Solution {
    public String solution(String s) {
        // 최종 결과 문자열을 저장할 변수 선언
        String answer = "";
        
        // 입력 문자열을 공백을 기준으로 나누어 배열에 저장
        String[] str = s.split("");
        
        // 대소문자를 번갈아가며 변경하기 위한 인덱스 변수
        int idx = 0;
        
        // 배열의 각 문자에 대해 반복
        for (int i = 0; i < str.length; i++) {
            // 현재 문자가 공백인 경우
            if (str[i].equals(" ")) {
                // 인덱스 초기화
                idx = 0;
            } 
            // 공백이 아니고 인덱스가 짝수인 경우 (0, 2, 4, ...)
            else if (idx % 2 == 0) {
                // 대문자로 변환
                str[i] = str[i].toUpperCase();
                // 인덱스 증가
                idx++;
            } 
            // 공백이 아니고 인덱스가 홀수인 경우 (1, 3, 5, ...)
            else if (idx % 2 != 0) {
                // 소문자로 변환
                str[i] = str[i].toLowerCase();
                // 인덱스 증가
                idx++;
            }
            
            // 결과 문자열에 현재 처리된 문자 추가
            answer += str[i];
        }
        
        // 최종 결과 문자열 반환
        return answer;
    }
}