석이의 개발일지
Lv2. JadenCase 문자열 만들기 본문
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