Poylib
기록형 프론트엔드
Poylib
전체 방문자
오늘
어제
  • 분류 전체보기 (91)
    • Programing (38)
      • Javascript (17)
      • Typescript (1)
      • React (9)
      • React-Native (6)
      • Git (4)
      • Next (1)
    • Study (36)
      • Algorithm (35)
      • Etc. (1)
    • Record (17)
      • Memoirs (12)
      • Group (5)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

  • 알고리즘
  • 코딩테스트
  • 기초
  • 백준
  • typescript
  • 자바스크립트
  • ReactNative
  • react
  • Git
  • 리액트
  • vite
  • Error
  • 코칭스터디
  • react-native
  • 프로그래머스
  • javascript
  • Object
  • 회고

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
Poylib

기록형 프론트엔드

[programmers / JavaScript] JadenCase 문자열 만들기
Study/Algorithm

[programmers / JavaScript] JadenCase 문자열 만들기

2022. 6. 14. 22:30
https://programmers.co.kr/learn/courses/30/lessons/12951?language=javascript#


sol1

function solution(s) {
    let answer = '';
    let arr = s.split(' ')
    answer = arr.map(v=>v.toLowerCase())
    .map(el => el=== "" ? "" : el.replace(el[0],el[0].toUpperCase()))
    return answer.join(' ')
}

조건중 공백 문자가 연속해서 나올 수 있다는 조건을 해결하는 게 까다로웠다. 공백을 아예 없애버리면 실패 케이스가 나오니 공백은 그대로 두고 첫 글자만 변환해야 했다. 

 

sol2

function solution(s) {
    s = s.toLowerCase()
    var answer = s.split(" ").map(s => {
        let arr = s.split("")
        if(arr[0] != null)
           arr[0] = arr[0].toUpperCase();
        return arr.join('');
    }).join(' ');

    return answer;
}

처음부터 문자열을 문자 하나하나 쪼개고 첫 문자만 변환한 후 다시 차례대로 조합하는 방법이다.

저작자표시 비영리 변경금지 (새창열림)

'Study > Algorithm' 카테고리의 다른 글

[BEAKJOON / node.js] 12904 A와 B  (0) 2022.06.16
[BEAKJOON / node.js] 9935 문자열 폭발  (0) 2022.06.15
[BEAKJOON / node.js] 1920 수 찾기  (2) 2022.06.12
[BEAKJOON / node.js] 10816 숫자 카드 2  (0) 2022.06.11
[BEAKJOON / node.js] 11659 구간 합 구하기 4  (0) 2022.06.10
    'Study/Algorithm' 카테고리의 다른 글
    • [BEAKJOON / node.js] 12904 A와 B
    • [BEAKJOON / node.js] 9935 문자열 폭발
    • [BEAKJOON / node.js] 1920 수 찾기
    • [BEAKJOON / node.js] 10816 숫자 카드 2
    Poylib
    Poylib
    모시깽 기록

    티스토리툴바