ABOUT ME

-

Today
-
Yesterday
-
Total
-
  • 프로그래머스 leve2.JadenCase (자바) - 문자열(StringTokenizer와 split의 차이)
    코딩테스트 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);
        }
    }
Designed by Tistory.