[자바스크립트/알고리즘] 프로그래머스 - JadenCase 문자열 만들기 (정규식)
728x90

문제 설명

JadenCase란 모든 단어의 첫 문자가 대문자이고, 그 외의 알파벳은 소문자인 문자열입니다. 문자열 s가 주어졌을 때, s를 JadenCase로 바꾼 문자열을 리턴하는 함수, solution을 완성해주세요.

 

제한 조건

  • s는 길이 1 이상인 문자열입니다.
  • s는 알파벳과 공백문자(" ")로 이루어져 있습니다.
  • 첫 문자가 영문이 아닐때에는 이어지는 영문은 소문자로 씁니다. ( 첫 번째 입출력 예 참고 )

 

입출력 예

s return
"3people unFollowed me" "3people Unfollowed Me"
"for the last week" "For The Last Week"

 

코드

function solution(s) {
    var answer = '';
    answer = s.replace(/[A-Z]+/g, letter => letter.toLowerCase()).replace(/^[a-z]|\s[a-z]/g, letter => letter.toUpperCase());
    
    return answer;
}

 

정규식 쓰고 8점 받았다! 요새 프로그래밍이 너무 어렵고 힘들었는데.. 힘이 난다. ^^

지금 보니까 굳이 변수 answer를 선언하지 않고 바로 s.replace~를 반환해도 된다...!

 

코드 설명

우선 주어진 문자열 s에서 대문자이면서 단어의 첫 시작이 아닌 문자( /[A-Z]+/g )를 찾아서

소문자로 변환( letter => letter.toLowerCase() )한다.

이렇게 변환된 문자열에서 단어의 첫 부분이 소문자이거나( /^[a-z]| )공백 뒤에 소문자( \s[a-z]/g )를 대문자로 변환( letter => letter.toUpperCase() )한다.

그리고 return~! 끝이다.

320x100