문제 설명
JadenCase란 모든 단어의 첫 문자가 대문자이고, 그 외의 알파벳은 소문자인 문자열입니다. 문자열 s가 주어졌을 때, s를 JadenCase로 바꾼 문자열을 리턴하는 함수, solution을 완성해주세요.
제한 조건
- s는 길이 1 이상인 문자열입니다.
- s는 알파벳과 공백문자(" ")로 이루어져 있습니다.
- 첫 문자가 영문이 아닐때에는 이어지는 영문은 소문자로 씁니다. ( 첫번째 입출력 예 참고 )
입출력 예
s return
3people unFollowed me | 3people Unfollowed Me |
for the last week | For The Last Week |
다음 문자에 따라서 앞 문자를 대문자로 만드는 문제이다.
문자열에서 문자 하나씩 뽑아가며 검사하면 간단하게 뽑힌다.
첫 글자를 처리하고 이전 값이 공백인지 검사하기 위해 char p를 따로 선언하였다.
첫글자가 숫자이거나 이미 대문자 일 수 있으니 검사를 하고, 수를 더해 주어야 한다. 32는 'a'에서 'A' 문자열의 ASCII 코드로 뺸 값이다.
사실 sysout 해서 알아냈다.
import java.util.*;
class Solution {
public String solution(String s) {
StringBuilder answer = new StringBuilder();
char p = ' ';
for(char c : s.toCharArray()){
if(p==' '){
if(c>='a' && c<='z')c-=32;
}else if(c>='A' && c<='Z')c+=32;
p = c;
answer.append(c);
}
return answer.toString();
}
}
실행 결과
'코딩테스트 연습' 카테고리의 다른 글
[ 프로그래머스 ] Lv2 연습문제 > 숫자의 표현 ( 자바 ) (0) | 2020.06.29 |
---|