JadenCase란 모든 단어의 첫 문자가 대문자이고, 그 외의 알파벳은 소문자인 문자열입니다. 단, 첫 문자가 알파벳이 아닐 때에는 이어지는 알파벳은 소문자로 쓰면 됩니다. (첫 번째 입출력 예 참고)
문자열 s가 주어졌을 때, s를 JadenCase로 바꾼 문자열을 리턴하는 함수, solution을 완성해주세요.
- s는 길이 1 이상 200 이하인 문자열입니다.
- s는 알파벳과 숫자, 공백문자(" ")로 이루어져 있습니다.
- 숫자는 단어의 첫 문자로만 나옵니다.
- 숫자로만 이루어진 단어는 없습니다.
- 공백문자가 연속해서 나올 수 있습니다.
"3people unFollowed me" | "3people Unfollowed Me" |
"for the last week" | "For The Last Week" |
※ 공지 - 2022년 1월 14일 제한 조건과 테스트 케이스가 추가되었습니다.

공백에 따라 하나 추가해줫더니... 문제는 공백이 여러개일 때도 유지해야된다...
그래서 아래처럼 기존 코드를 수정하여 대응하려 했으나(&&으로 덕지덕지 조건 붙임) 안됨.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
function solution(s) {
let arr1 = [...s]
arr1[0] = arr1[0].toUpperCase()
for(let i =1; i<arr1.length; i++) {
if(arr1[i] === arr1[i].toUpperCase()) {
arr1[i] = arr1[i].toLowerCase()
}
}
for(let i =1; i<arr1.length; i++) {
if(arr1[i] == ' ' && arr1[i] != arr1[arr1.length -1] && arr1[i+1] != ' ' ){
arr1[i+1] = arr1[i+1].toUpperCase()
}
}
return arr1.join("")
}
|
cs |
i+1이 아니라, i-1로 대응했다면 문제가 풀렸을 텐데...
i+1 로 대응하다보니 공백을 매꾸는게 안되었다.
<제출 답안>
function solution(s) {
let arr = s.split('').map((x) => x.toLowerCase());
arr[0] = arr[0].toUpperCase();
for (i = 1; i < arr.length; i++) {
if (arr[i - 1] === ' ') {
arr[i] = arr[i].toUpperCase();
}
}
return arr.join('');
}
'🗃️javascript > 프로그래머스' 카테고리의 다른 글
최대공약수와 최소공배수(Lv.1)[] (0) | 2023.03.22 |
---|---|
삼각형의 완성조건 (2)(Lv.0) (0) | 2023.03.22 |
구슬을 나누는 경우의 수(Lv.0)[factorial을 부분함수로 구현하기] (0) | 2023.03.22 |
직사각형 별찍기(Lv.1)[`${}`은 "",''과 다르게 {}안에서 함수사용 가능] (0) | 2023.03.22 |
행렬의 덧셈(Lv.1)[2차원 배열(행렬)에 대한 이해] (0) | 2023.03.18 |