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();
}
반응형