[프로그래머스] [Level1] 이상한 문자 만들기 - Java

2021. 1. 5. 14:31프로그래밍/알고리즘

반응형

💁‍♀️ 링크

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

 

📃 문제 

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

 

제한 사항

  • 문자열 전체의 짝/홀수 인덱스가 아니라, 단어(공백을 기준)별로 짝/홀수 인덱스를 판단해야합니다.
  • 첫 번째 글자는 0번째 인덱스로 보아 짝수번째 알파벳으로 처리해야 합니다.

입출력 예

 s  return
 try hello world  TrY HeLlO WoRlD

 

🐾 문제풀이

1. StringTokenizer을 사용해 공백을 기준으로 문자열을 자른다.

   (3번째 인자값을 true로 두어, 공백문자까지 토큰으로 포함)

 

2. 순차적으로 토큰을 가져온다

  • split("")을 이용해서 배열로 만들고, 배열의 인덱스가 홀수인 경우만 소문자로 변경해준다.
  • 배열을 문자열로 변환하여 answer에 더해준다.

 

* StringTokenizer 사용법은 아래의 포스팅에 더 자세하게 나와있습니다.

 

[JAVA] StringTokenizer 사용법

📚 생성자(Constructor) public StringTokenizer(String str); public StringTokenizer(String str, String delim); public StringTokenizer(String str, String delim, boolean returnDelims); Parameters str ..

jeleedev.tistory.com

 

 

💻 코드

import java.util.StringTokenizer;
class Solution {
    public String solution(String s) {
        String answer = "";
        
        // 공백을 기준으로 문자열을 나눈다.
        StringTokenizer words = new StringTokenizer(s.toUpperCase(), " ", true);
        
        // 순차적으로 토큰을 가져와 토큰의 홀수번째 문자를 소문자로 변경하고, answer문자열에 더해준다.
        while(words.hasMoreTokens()){
            String[] word = words.nextToken().split("");
            for(int j=1; j<word.length; j+=2){
                word[j] = word[j].toLowerCase();
            }
            answer += String.join(",", word);
        }
        return answer.replace(",", "");
    }
}

 

 

 

반응형