본문 바로가기

공부, 알고리즘/프로그래머스

[프로그래머스/JAVA] Level 1. 이상한 문자 만들기

programmers.co.kr/learn/courses/30/lessons/12930

 

코딩테스트 연습 - 이상한 문자 만들기

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

programmers.co.kr

# 문제설명

문자열 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를 리턴한다.