이상한 문자 만들기

  • java

posted on 28 Aug 2024 under category java in series algorithm

프로그래머스 코딩테스트 Lv. 1

이상한 문자 만들기

출처: 프로그래머스 코딩 테스트
이상한 문자 만들기

문제 설명

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

제한 조건

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

입출력 예

s return
“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[] words = s.split(" ", -1); // 문자열을 공백으로 나누어 배열로 변환
        for (String word : words) {
            StringBuilder sb = new StringBuilder(); // 변환된 단어를 저장할 StringBuilder
            for (int i = 0; i < word.length(); i++) { // 각 단어의 문자 하나씩 처리
                if (i % 2 == 0) { // 짝수 인덱스
                    sb.append(Character.toUpperCase(word.charAt(i))); // 대문자로 변환 후 추가
                } else { // 홀수 인덱스
                    sb.append(Character.toLowerCase(word.charAt(i))); // 소문자로 변환 후 추가
                }
            }
            answer += sb.toString() + " "; // 변환된 단어를 answer에 추가하고 공백 추가
        }
        return answer.substring(0, answer.length() - 1); // 마지막 공백 제거 후 반환
    }
}


설명

  1. 문자열 분리: split(“ “, -1)은 공백을 기준으로 문자열을 나누며, -1은 연속된 공백도 빈 문자열로 유지하도록 함. 이 부분은 다중 공백을 처리하기 위해 필요.

  2. 단어 변환 및 조합: 각 단어별로 StringBuilder를 사용하여 짝수 인덱스는 대문자, 홀수 인덱스는 소문자로 변환. 변환된 단어는 최종 결과 문자열에 공백을 포함하여 추가.

  3. 공백 처리: 마지막에 불필요하게 추가된 공백을 제거하기 위해 substring(0, answer.length() - 1)을 사용하여 최종 결과 문자열의 끝에 있는 공백을 제거, 반환.