[프로그래머스] '이상한 문자 만들기' 문제 자바스크립트 알고리즘
[프로그래머스] '이상한 문자 만들기' 문제 자바스크립트 알고리즘
https://programmers.co.kr/learn/courses/30/lessons/12930
Q. 이상한 문자 만들기
문자열 s는 한 개 이상의 단어로 구성되어 있습니다. 각 단어는 하나 이상의 공백문자로 구분되어 있습니다. 각 단어의 짝수번째 알파벳은 대문자로, 홀수번째 알파벳은 소문자로 바꾼 문자열을 리턴하는 함수, solution을 완성하세요.
제한사항
- 문자열 전체의 짝/홀수 인덱스가 아니라, 단어(공백을 기준)별로 짝/홀수 인덱스를 판단해야합니다.
- 첫 번째 글자는 0번째 인덱스로 보아 짝수번째 알파벳으로 처리해야 합니다.
입출력 예
s | return |
---|---|
"try hello world" | "TrY HeLlO WoRlD" |
입출력 예설명
"try hello world"는 세 단어 "try", "hello", "world"로 구성되어 있습니다. 각 단어의 짝수번째 문자를 대문자로, 홀수번째 문자를 소문자로 바꾸면 "TrY", "HeLlO", "WoRlD"입니다. 따라서 "TrY HeLlO WoRlD" 를 리턴합니다.
- 코드
function solution(s) {
var answer = "";
const small = Array.from({length:26},((a,i)=> String.fromCharCode(i + 97) ));
const big = Array.from({length:26},((a,i)=> String.fromCharCode(i + 65) ));
var arrS = s.split(" ");
arrS.map((a)=> {
for(let i=0; i<a.length; i++){
var index = small.includes(a[i]) ? small.indexOf(a[i]): big.indexOf(a[i]); // 인덱스 찾기
if(i%2===0) answer += big[index];
else answer += small[index];
}
answer += " " // for문이 끝나면 띄워쓰기
})
return answer.slice(0,-1); // 마지막 띄워쓰기 제거
}
다른풀이
function solution(s) {
return s.split(' ').map((a)=>a.split('').map((j,i)=>i%2===0?j.toUpperCase():j.toLowerCase()).join('')).join(' ');
}
참고
Array.from()
Array.from({length: 5}, (v, i) => i); // [0, 1, 2, 3, 4]
Array.from({length: 7}, (v, i) => i-3); // [-3, -2, -1, 0, 1, 2, 3]
charCodeAt / fromCharCode
var val = "charCodeAt";
var.charCodeAt(4); // 인덱스 4에 해당하는 C의 아스키코드 67 반환
var val2 = 111;
String.fromCharCode(var2) // 아스키코드 111에 해당하는 문자 'o' 반환
toUpperCase()/toLowerCase()
var a = "ABC abc" ;
a.toUpperCase() ; // ABC ABC
a.toLowerCase() ; // abc abc
Author And Source
이 문제에 관하여([프로그래머스] '이상한 문자 만들기' 문제 자바스크립트 알고리즘), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://velog.io/@dlzagu/프로그래머스-이상한-문자-만들기-문제-자바스크립트-알고리즘저자 귀속: 원작자 정보가 원작자 URL에 포함되어 있으며 저작권은 원작자 소유입니다.
우수한 개발자 콘텐츠 발견에 전념 (Collection and Share based on the CC Protocol.)