[Java] JadenCase 문자열 만들기

2019. 7. 16. 19:17알고리즘

문제 설명

JadenCase란 모든 단어의 첫 문자가 대문자이고, 그 외의 알파벳은 소문자인 문자열입니다. 문자열 s가 주어졌을 때, s를 JadenCase로 바꾼 문자열을 리턴하는 함수, solution을 완성해주세요.


제한 조건

  • s는 길이 1 이상인 문자열입니다.
  • s는 알파벳과 공백문자(" ")로 이루어져 있습니다.
  • 첫 문자가 영문이 아닐때에는 이어지는 영문은 소문자로 씁니다. ( 첫번째 입출력 예 참고 )

입출력 예

s return
3people unFollowed me 3people Unfollowed Me
for the last week For The Last Week

나의 풀이

정규식을 사용하여 아래와 같이 풀었다.

public static String solution(String s) {
    String answer = "";
    String[] sArr = s.split("");
    String isNumber = "^[0-9]*$";
    String isLowerCase = "^[a-z]*$";
    String isUpperCase = "^[A-Z]*$";
    if (sArr[0].matches(isLowerCase)) // 첫번째 문자가 소문자일때
           sArr[0] = sArr[0].toUpperCase();// 대문자로 변환
    for (int i = 1; i < sArr.length; i++) {
        if (sArr[i - 1].equals(" ")) {// i-1이 공백일 때
            if (sArr[i].matches(isLowerCase))// i번째 문자가 소문자이면
                sArr[i] = sArr[i].toUpperCase(); // 대문자로 변환
        }else {// i-1이 공백이 아닐 때
            if (sArr[i].matches(isUpperCase)) // i가 대문자이면
                sArr[i] = sArr[i].toLowerCase();// 소문자로 변환
        }
    }
    for (String i : sArr)
        answer += i;
    return answer;
}