코딩테스트

프로그래머스 leve2.JadenCase (자바) - 문자열(StringTokenizer와 split의 차이)

leeeehhjj 2023. 2. 4. 18:11
문제 설명

JadenCase란 모든 단어의 첫 문자가 대문자이고, 그 외의 알파벳은 소문자인 문자열입니다. 단, 첫 문자가 알파벳이 아닐 때에는 이어지는 알파벳은 소문자로 쓰면 됩니다. (첫 번째 입출력 예 참고)
문자열 s가 주어졌을 때, s를 JadenCase로 바꾼 문자열을 리턴하는 함수, solution을 완성해주세요.

제한 조건
  • s는 길이 1 이상 200 이하인 문자열입니다.
  • s는 알파벳과 숫자, 공백문자(" ")로 이루어져 있습니다.
    • 숫자는 단어의 첫 문자로만 나옵니다.
    • 숫자로만 이루어진 단어는 없습니다.
    • 공백문자가 연속해서 나올 수 있습니다.
입출력 예sreturn
"3people unFollowed me" "3people Unfollowed Me"
"for the last week" "For The Last Week"

처음에는 공백이 여러개일 때 여러개의 공백을 그대로 출력해야 한다는 걸 생각못했다.
 

초기코드

import java.util.*;
class Solution {
    public String solution(String s) {
        String answer = "";
        StringTokenizer st = new StringTokenizer(s);
        while(st.hasMoreTokens()) {
            String str = st.nextToken();
            String first = Character.toString(str.charAt(0));
            String others = str.substring(1,str.length());
            String tmp = "";
            if (first.matches("^[a-z]$")) {
                first = first.toUpperCase();
            }
            else if(first.matches("^[A-Z]$")) {
                first = first.toLowerCase();
            }
            
            others = others.toLowerCase();
            answer += (first + others + " ");
        }
        
        return answer.substring(0, answer.length()-1);
    }
}

 

StringTokenizer : 공백을 기준으로 문자열들만 토큰으로 인식(빈 문자열은 인식x)

split : 빈 문자열도 토큰으로 인식

 

예를 들어 i   have a 를 출력 시

StringTokenizer는 i,have,a를

split은 i, ,have,a를 반환한다.

 

따라서 이 문제에서는 stringTokenizer 보다 split을 활용해 공백이 여러개인 경우를 처리해줘야 한다.

또 주의할 점은 if (tmp.length()==0) 이 부분을 if (tmp.equals(" ")) 이렇게 하면 원하는 값을 확인하지 못한다. 왜냐하면 split을 실행했을 때 공백인 문자열은 " " 이렇게 공백 한 칸이 저장되는게 아니라 그냥 빈 문자열이 저장되기 때문이다.

import java.util.*;
class Solution {
    public String solution(String s) {
        String answer = "";
        String[] str = s.split(" ");
        for (int i = 0; i < str.length; i++) {
            String tmp = str[i];
            if (tmp.length() == 0) {
                answer += " ";
            }
            else {
                answer += tmp.substring(0,1).toUpperCase();
                answer += tmp.substring(1,tmp.length()).toLowerCase();
                answer += " "; //공백 추가
            }
        }
        if (s.substring(s.length()-1, s.length()).equals(" ")) return answer;
        //마지막 문자열이 공백인 경우 그대로 출력하고 그렇지 않으면 마지막에 추가해준 공백을 제거하고 출력한다
        return answer.substring(0,answer.length()-1);
    }
}