[프로그래머스/JAVA] Level 1. 이상한 문자 만들기
programmers.co.kr/learn/courses/30/lessons/12930
# 문제설명
문자열 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 = "";
int idx = 0;
String[] strArr = s.split("");
for(int i=0; i<strArr.length; i++) {
if((" ").equals(strArr[i])) idx = 0;
else {
if(idx%2==0) {
idx++;
strArr[i] = strArr[i].toUpperCase();
}else {
idx++;
strArr[i] = strArr[i].toLowerCase();
}
}
answer += strArr[i];
}
return answer;
}
}
#라인4
문자열 인덱스를 구분할 변수를 선언한다.
#라인6
입력받은 문자열을 split()을 활용해서 한 글자씩 String배열에 담는다.
#라인8, 9
for문을 통해 공백을 먼저 처리한다.
문자열 중에서 공백을 만나면 idx를 0으로 초기화 한다.
그래야 각 단어마다 정확한 짝수, 홀수번째를 구분할 수 있다.
#라인11 ~ 13
만약 공백이 아니라면 이 단어가 짝수번째인지 홀수번째인지 계산한다.
짝수번째면 대문자로 변경하고(toUpperCase()) idx++를 한다.
#라인14 ~ 16
홀수번째면 소문자로 변경하고(toLowerCase()) idx++를 한다.
여기까지 한 글자를 처리하는 과정이다.
#라인19, 22
여기까지 한 글자 처리를 완료하면 answer 변수에 담는다.
이런식으로 문자열 s를 처리하면 answer를 리턴한다.