이상한 문자 만들기
-
문제 설명
문자열 s는 한 개 이상의 단어로 구성되어 있습니다. 각 단어는 하나 이상의 공백문자로 구분되어 있습니다. 각 단어의 짝수번째 알파벳은 대문자로, 홀수번째 알파벳은 소문자로 바꾼 문자열을 리턴하는 함수, solution을 완성하세요.
제한 사항
- 문자열 전체의 짝/홀수 인덱스가 아니라, 단어(공백을 기준)별로 짝/홀수 인덱스를 판단해야합니다.
- 첫 번째 글자는 0번째 인덱스로 보아 짝수번째 알파벳으로 처리해야 합니다.
입출력 예 설명
“try hello world”는 세 단어 “try”, “hello”, “world”로 구성되어 있습니다. 각 단어의 짝수번째 문자를 대문자로, 홀수번째 문자를 소문자로 바꾸면 “TrY”, “HeLlO”, “WoRlD”입니다. 따라서 “TrY HeLlO WoRlD” 를 리턴합니다.
문제 풀이
- 공백을 포함한 각 문자를 배열에 저장한다.
- 공백을 기준으로 분리된 문자열마다 0부터 다시 값을 시작해야하므로 count를 선언, 배열에 공백이 있을 경우는 count를 0으로 초기화
- count가 짝수인 경우 대문자, 홀수인 경우는 소문자로 변환
- join을 사용해 문자열 다시 합치기
class Solution {
public String solution(String s) {
String answer = "";
// 1. 문자열의 문자 분리 후 배열에 저장
String[] str = s.split("");
int count = 0; // 짝홀수 계산할 변수선언
for (int i = 0; i < s.length(); i++) {
// 2-1. 공백이 있을 경우 count값 초기화
if (str[i].equals(" ")) {
count = 0;
continue;
}
// 2-2. 짝수인 경우 대문자 변환
if (count%2 == 0) str[i] = str[i].toUpperCase();
// 2-3. 홀수인 경우 소문자 변환
else str[i] = str[i].toLowerCase();
count ++;
}
answer = String.join("", str);
return answer;
}
}