[프로그래머스] '이상한 문자 만들기' 문제 자바스크립트 알고리즘

[프로그래머스] '이상한 문자 만들기' 문제 자바스크립트 알고리즘


https://programmers.co.kr/learn/courses/30/lessons/12930

Q. 이상한 문자 만들기


문자열 s는 한 개 이상의 단어로 구성되어 있습니다. 각 단어는 하나 이상의 공백문자로 구분되어 있습니다. 각 단어의 짝수번째 알파벳은 대문자로, 홀수번째 알파벳은 소문자로 바꾼 문자열을 리턴하는 함수, solution을 완성하세요.

제한사항


  • 문자열 전체의 짝/홀수 인덱스가 아니라, 단어(공백을 기준)별로 짝/홀수 인덱스를 판단해야합니다.
  • 첫 번째 글자는 0번째 인덱스로 보아 짝수번째 알파벳으로 처리해야 합니다.

입출력 예


sreturn
"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


좋은 웹페이지 즐겨찾기