석이의 개발일지

Lv2. JadenCase 문자열 만들기 본문

Algorithm

Lv2. JadenCase 문자열 만들기

믹석이 2023. 3. 16. 13:30
728x90

문제 설명

JadenCase란 모든 단어의 첫 문자가 대문자이고, 그 외의 알파벳은 소문자인 문자열입니다. 단, 첫 문자가 알파벳이 아닐 때에는 이어지는 알파벳은 소문자로 쓰면 됩니다. (첫 번째 입출력 예 참고)
문자열 s가 주어졌을 때, s를 JadenCase로 바꾼 문자열을 리턴하는 함수, solution을 완성해주세요.

제한 조건

s는 길이 1 이상 200 이하인 문자열입니다.
s는 알파벳과 숫자, 공백문자(" ")로 이루어져 있습니다.
숫자는 단어의 첫 문자로만 나옵니다
.숫자로만 이루어진 단어는 없습니다.
공백문자가 연속해서 나올 수 있습니다.

입출력 예

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

나의 풀이

function solution(s) {
    let str = s.toLowerCase().split(" ") // 일단 소문자로 다 통일 시킨후 나눈다.
    // return str.map((a) => a[0].toUpperCase() + a.slice(1).toLowerCase()).join(" ")
    // map으로 돌려 a[0] 첫번째 요소는 대문자로 바꾸고 + a.slice(1) 첫번째 요소를 제외한 두번째 요소부터 끝까지 소문자로 바꾼후 join(" ") 공백으로 합친다.
    // 하지만 런타임 에러 발생 ㅋㅋ
    
     return str.map((a) => a.charAt(0).toUpperCase() + a.slice(1).toLowerCase()).join(" ")
     // 위에 풀이가 런타임 문제가 나서 a[0] 이렇게 첫번째요소로 가져오는게 런타임 문제였던거 같다 그래서 charAt 을 사용해 문자열 첫번째를 사용
    
}

다른 풀이

function solution(s) {
    return s.split(" ").map(v => v.charAt(0).toUpperCase() + v.substring(1).toLowerCase()).join(" ");
}
LIST

'Algorithm' 카테고리의 다른 글

Lv2. 최솟값 만들기  (0) 2023.03.17
Lv2. 올바른 괄호  (2) 2023.03.16
Lv.2 최댓값과 최솟값  (2) 2023.03.15
시간 복잡도  (6) 2023.02.13
자료구조  (0) 2023.02.13
Comments