Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
Tags
- 함수
- 알고리즘
- 코드스쿼드
- 자바
- 회고의 회고
- toast
- ES6
- html
- CSS
- express
- 우아한테크코스
- Hello Coding HTML5+CSS3
- 우아한형제들
- 자바스크립트
- 자바스크립트 객체
- 모듈 배포하기
- 러닝 자바스크립트
- 레인지 슬라이더
- npm
- 리액트
- 네이버 테크 콘서트
- 주간 회고
- 우아한테크캠프
- 토이프로젝트
- 우아한테크캠프 4기
- 개인 프로젝트
- 토이 프로젝트
- 프로그래머스
- 인사이드 자바스크립트
- AWS
Archives
- Today
- Total
블로그
[프로그래머스, 자바스크립트] 알고리즘-26 이상한 문자 만들기 본문
출처 : 프로그래머스 알고리즘 코딩테스트 Level.1
https://programmers.co.kr/learn/courses/30/lessons/12930?language=javascript
문제
문자열 s는 한 개 이상의 단어로 구성되어 있습니다.
각 단어는 하나 이상의 공백문자로 구분되어 있습니다.
각 단어의 짝수번째 알파벳은 대문자로,
홀수번째 알파벳은 소문자로 바꾼 문자열을 리턴하는 함수,
solution을 완성하세요.
제한 조건
- 문자열 전체의 짝/홀수 인덱스가 아니라, 단어(공백을 기준)별로 짝/홀수 인덱스를 판단해야합니다.
- 첫 번째 글자는 0번째 인덱스로 보아 짝수번째 알파벳으로 처리해야 합니다.
입출력 예시
strings return 'try hello world' 'TrY HeLlO WoRlD'
입출력 예시 설명
try hello world는 세 단어 try, hello, world로 구성되어 있습니다.
각 단어의 짝수번째 문자를 대문자로, 홀수번째 문자를 소문자로 바꾸면 TrY, HeLlO, WoRlD입니다.
따라서 TrY HeLlO WoRlD 를 리턴합니다.
풀이 과정
1. 문자열을 배열을 통해 단어별로 분리
2. 각 단어별 문자들을 순회
3. 짝수, 홀수에 따른 대소문자 변환 실행
4. 배열을 다시 문자열로 변환
5. 반환
답안
function solution(s) {
return s.split(' ').map( v => v.split('').map((v, i) => i%2 == 0 ? v.toUpperCase() : v.toLowerCase()).join('') ).join(' ');
}
split과 join을 두 번씩 쓰지 않고 푸는 방법도 있지않을까?
'알고리즘' 카테고리의 다른 글
[프로그래머스, 자바스크립트] 알고리즘-28 자연수 뒤집어 배열로 만들기 (0) | 2019.12.01 |
---|---|
[프로그래머스, 자바스크립트] 알고리즘-27 자릿수 더하기 (0) | 2019.12.01 |
[프로그래머스, 자바스크립트] 알고리즘-25 문자열 내 마음대로 정렬하기 (0) | 2019.12.01 |
[프로그래머스, 자바스크립트] 알고리즘-24 소수 찾기 (0) | 2019.11.30 |
[프로그래머스, 자바스크립트] 알고리즘-23 체육복 (0) | 2019.11.29 |
Comments