[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;
}
'알고리즘' 카테고리의 다른 글
[Java] 사각형 좌표 구하기 (0) | 2019.03.15 |
---|---|
[Java] 별찍기 문제 (0) | 2019.03.15 |
[Java] 프로그래머스 Level2 쇠막대기 (0) | 2019.03.10 |
[Java] 프로그래머스 Level2 H-Index (0) | 2019.03.06 |
[Java] 프로그래머스 Level2 가장 큰 수 (0) | 2019.03.05 |