본문 바로가기

코딩테스트

[프로그래머스] level1. 시저 암호 (javascript)

반응형

문제

어떤 문장의 각 알파벳을 일정한 거리만큼 밀어서 다른 알파벳으로 바꾸는 암호화 방식을 시저 암호라고 합니다.
예를 들어 "AB"는 1만큼 밀면 "BC"가 되고, 3만큼 밀면 "DE"가 됩니다. "z"는 1만큼 밀면 "a"가 됩니다. 문자열 s와 거리 n을 입력받아 s를 n만큼 민 암호문을 만드는 함수, solution을 완성해 보세요.

나의 풀이

초기코드(오답)

function solution(s, n) {
    var answer = '';

    for(let i = 0 ; i < s.length;i++){
        const tmp = s.charCodeAt(i)
        if (tmp == 32){
            answer += " "
        } else if ( 64 < tmp +n && tmp+n < 91){
            answer += String.fromCharCode(tmp+n)
        } else if ( 90 < tmp+n && tmp +n < 97){
            answer += String.fromCharCode(tmp+n-90+64)
        } else if (96 < tmp+n && tmp +n < 123){
            answer += String.fromCharCode(tmp+n)
        } else if (122 < tmp +n){
             answer += String.fromCharCode(tmp+n - 122 + 96)
        }

    }

    return answer;
}

 

문자열 -> 아스키코드 : s.charCodeAt()
아스키코드 -> 문자열 : String.fromCharCode()

다른이들의 풀이

방법1.

function solution(s, n) {

    return s.split("").map((el)=>{
        if (el == " "){
            return el;
        }
        const tmp = el.charCodeAt()
        return el.toUpperCase().charCodeAt()+n > 90 
            ? String.fromCharCode(tmp+n-26) 
            : String.fromCharCode(tmp+n)
    }).join('')

}

 

케이스를 줄이기 위해 조건을 비교하기전에 전부 대문자로 바꿔줬다.
그 후 삼항연산자로 한번만 계산.

 

if, for문에 너무 의존하지말고, 최대한 map을 써보도록 해보자(습관을 들여보자.)
추가로 삼항연산자도 써보도록 해보자.
split("")와 join('')은 거의 세트라 생각하자.

 

방법2. 아스키코드 없는 풀이

function solution(s, n) {
    var upper = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
    var lower = "abcdefghijklmnopqrstuvwxyz";
    var answer= '';

    for(var i =0; i <s.length; i++){
        var text = s[i];
        if(text == ' ') {
            answer += ' '; 
            continue;
        }
        var textArr = upper.includes(text) ? upper : lower;
        var index = textArr.indexOf(text)+n;
        if(index >= textArr.length) index -= textArr.length;
        answer += textArr[index];
    }
    return answer;
}
반응형