코딩테스트
프로그래머스 leve2.JadenCase (자바) - 문자열(StringTokenizer와 split의 차이)
leeeehhjj
2023. 2. 4. 18:11
문제 설명
JadenCase란 모든 단어의 첫 문자가 대문자이고, 그 외의 알파벳은 소문자인 문자열입니다. 단, 첫 문자가 알파벳이 아닐 때에는 이어지는 알파벳은 소문자로 쓰면 됩니다. (첫 번째 입출력 예 참고)
문자열 s가 주어졌을 때, s를 JadenCase로 바꾼 문자열을 리턴하는 함수, solution을 완성해주세요.
- s는 길이 1 이상 200 이하인 문자열입니다.
- s는 알파벳과 숫자, 공백문자(" ")로 이루어져 있습니다.
- 숫자는 단어의 첫 문자로만 나옵니다.
- 숫자로만 이루어진 단어는 없습니다.
- 공백문자가 연속해서 나올 수 있습니다.
"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);
}
}