본문 바로가기

코딩테스트 연습

[ 프로그래머스] Lv2 연습문제 > JadenCase 문자열 만들기 : java

문제 설명

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();
    }
}

실행 결과