Java/코딩테스트

[java/프로그래머스/12930] 이상한 문자 만들기 (charAt(i), toCharArray(), result.append(c), index = 0)

Se On 2025. 2. 18. 13:38

✏️ 문제 설명

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

 

제한 사항

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

✏️ code 1차

    // 풀이 1: charAt
    public String solution1(String s) {
        StringBuilder result = new StringBuilder();
        int index = 0;
        for (int i = 0; i < s.length(); i++) {
            char c = s.charAt(i);
            if (c == ' ') {
                result.append(" ");
                index = 0;
            } else {
                result.append((index++ % 2 == 0) ? Character.toUpperCase(c) : Character.toLowerCase(c));
            }
        }
        return result.toString();
    }

✏️ code 2차

📌 toCharArray(), result.append(c)
(1) toCharArray()
- charAt(i)는 호출할 때마다 내부에서 char[]배열을 참조하기 때문에 매 호출마다 메서드 오버헤드가 발생할 수 있습니다.
- toCharArray()한 번에 전체 문자열을 char[]로 변환하고 이후 반복문에서 직접 배열에 접근하기 때문에 추가적인 메서드 호출 오버헤드가 없습니다.
(2) 공백 처리 최적화: append(" ") 대신 append(c)를 사용합니다.
    // 풀이 2: toCharArray
    public String solution2(String s) {
        StringBuilder result = new StringBuilder(s.length());
        int index = 0;
        for (char c : s.toCharArray()) {
            if (c == ' ') {
                result.append(c);
                index = 0;
            } else {
                result.append((index++ % 2 == 0) ? Character.toUpperCase(c) : Character.toLowerCase(c));
            }
        }
        return result.toString();
    }
반응형