이상한 문자 만들기
posted on 28 Aug 2024 under category java in series algorithm
출처: 프로그래머스 코딩 테스트
이상한 문자 만들기
문제 설명
문자열 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); // 마지막 공백 제거 후 반환
}
}
문자열 분리: split(“ “, -1)은 공백을 기준으로 문자열을 나누며, -1은 연속된 공백도 빈 문자열로 유지하도록 함. 이 부분은 다중 공백을 처리하기 위해 필요.
단어 변환 및 조합: 각 단어별로 StringBuilder를 사용하여 짝수 인덱스는 대문자, 홀수 인덱스는 소문자로 변환. 변환된 단어는 최종 결과 문자열에 공백을 포함하여 추가.
공백 처리: 마지막에 불필요하게 추가된 공백을 제거하기 위해 substring(0, answer.length() - 1)을 사용하여 최종 결과 문자열의 끝에 있는 공백을 제거, 반환.