2022. 3. 28. 16:17
JadenCase란 모든 단어의 첫 문자가 대문자이고, 그 외의 알파벳은 소문자인 문자열입니다. 단, 첫 문자가 알파벳이 아닐 때에는 이어지는 알파벳은 소문자로 쓰면 됩니다. (첫 번째 입출력 예 참고)
문자열 s가 주어졌을 때, s를 JadenCase로 바꾼 문자열을 리턴하는 함수, solution을 완성해주세요.제한 조건
- s는 길이 1 이상 200 이하인 문자열입니다.
- s는 알파벳과 숫자, 공백문자(" ")로 이루어져 있습니다.
- 숫자는 단어의 첫 문자로만 나옵니다.
- 숫자로만 이루어진 단어는 없습니다.
- 공백문자가 연속해서 나올 수 있습니다.
입출력 예
sreturn
"3people unFollowed me" | "3people Unfollowed Me" |
"for the last week" | "For The Last Week" |
※ 공지 - 2022년 1월 14일 제한 조건과 테스트 케이스가 추가되었습니다.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
|
import java.util.*;
class Solution {
public String solution(String s) {
String answer = "";
Queue<String> queue = new LinkedList<>();
for(int i=0; i<s.length(); i++){
queue.add(s.substring(i,i+1));
}
// answer += queue.poll();
// System.out.println("Hello queue "+queue);
while(!queue.isEmpty()){
if(queue.peek().equals(" ")){ //공백일 경우
answer += queue.poll(); //우선 넣어주고
if(!queue.isEmpty()){
if(!queue.peek().equals(" ")){ //다음이 공백이 아니면
answer +=queue.poll().toUpperCase();
} else { //또 공백이면
continue;
}
} else {
break;
}
}else {
if(answer.length() <1){
answer+= queue.poll().toUpperCase(); //대문자로
} else {
answer+= queue.poll().toLowerCase(); //소문자로
}
}
}
return answer;
}
}
|
cs |
공백체크가 중요, 그중에서도 문장의 맨 끝에 공백이 오는 경우를 체크해야 함
이 부분 때문에 계속 런타임에러가 발생해서 해결하는데 시간이 걸림
'java' 카테고리의 다른 글
[프로그래머스]신규 아이디 추천 (0) | 2022.03.29 |
---|---|
[프로그래머스] k진수에서 소수 개수 구하기 (0) | 2022.03.29 |
[프로그래머스] 이진 변환 반복하기 (0) | 2022.03.28 |
[프로그래머스]로또의 최고 순위와 최저 순위 (0) | 2022.03.28 |
[프로그래머스]피보나치 수 (0) | 2022.03.18 |