ALGORITHM/PROGRAMMERS

[프로그래머스] JadenCase 문자열 만들기 | javascript

heeney 2021. 8. 13. 22:53
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) {    
    return s.toLowerCase().split(' ').map(v =>
        v = v.replace(/^./, v.charAt(0).toUpperCase())
    ).join(' ');
}

이상하게 v.charAt을 v[0]으로 하면 안됐다.
charAt을 사용해야 하는 이유가 있고, 맨 앞이 공백일 가능성을 두고 코드를 작성해야 한다고 한다.

https://thisthat.dev/string-char-at-vs-string-bracket-notation/

 

this vs that - string.charAt(i) vs string[i]

string.charAt(i) vs string[i]

thisthat.dev

charAt은 존재하지 않는 index(공백 등)를 인자로 전달하면 공백이 출력된다. 그런데 string[i]는 undefined가 출력되어 그렇다고 이해했다.

여러 경우의 수에 있어서 첫번째 문자열이 공백일 수 있으므로 undefined가 뜨지 않고 정확하게 우리가 원하는 답을 도출해내기 위해 여기서 사용되어야 했다고 느꼈다.

728x90