본문 바로가기
알고리즘 스터디/백준 알고리즘 기초 1

[백준 11655번 ROT 13 - node.js] [알고리즘 기초 1/2]

by 레일라오리덕 2021. 7. 30.
728x90

https://www.acmicpc.net/problem/11655

 

11655번: ROT13

첫째 줄에 알파벳 대문자, 소문자, 공백, 숫자로만 이루어진 문자열 S가 주어진다. S의 길이는 100을 넘지 않는다.

www.acmicpc.net

 

문제

 

ROT13은 카이사르 암호의 일종으로 영어 알파벳을 13글자씩 밀어서 만든다.

예를 들어, "Baekjoon Online Judge"를 ROT13으로 암호화하면 "Onrxwbba Bayvar Whqtr"가 된다. ROT13으로 암호화한 내용을 원래 내용으로 바꾸려면 암호화한 문자열을 다시 ROT13하면 된다. 앞에서 암호화한 문자열 "Onrxwbba Bayvar Whqtr"에 다시 ROT13을 적용하면 "Baekjoon Online Judge"가 된다.

ROT13은 알파벳 대문자와 소문자에만 적용할 수 있다. 알파벳이 아닌 글자는 원래 글자 그대로 남아 있어야 한다. 예를 들어, "One is 1"을 ROT13으로 암호화하면 "Bar vf 1"이 된다.

문자열이 주어졌을 때, "ROT13"으로 암호화한 다음 출력하는 프로그램을 작성하시오.

 

입력

 

첫째 줄에 알파벳 대문자, 소문자, 공백, 숫자로만 이루어진 문자열 S가 주어진다. S의 길이는 100을 넘지 않는다.

 

출력

 

첫째 줄에 S를 ROT13으로 암호화한 내용을 출력한다.

 

예제 입출력

 

입력 출력
Baekjoon Online Judge Onrxwbba Bayvar Whqtr
One is 1 Bar vf 1

 

풀이[node.js]

 

 

 

728x90

inputs으로 들어온 값들의 아스키코드를  char에 담아주고, 65~90의 숫자이면 대문자, 97~122는 소문자, 32는 공백, 그 외의 숫자는 inputs[i]값을 그대로 answer에 넣어주었습니다.

공백인 경우에도 그 값을 그대로 넣어주면 됩니다.

대문자와 소문자의 경우, 원리는 똑같습니다.

아스키코드에 13을 더해주고 해당 값이 대문자의 범위인 90을 넘는다면 90에서 26을 빼준 값을 다시 대문자로 변환을,

소문자인 경우 122를 넘는다면 똑같이 26을 빼준 다음에 다시 대문자로 변환을 해주면 됩니다.

var fs = require('fs');
var inputs = fs.readFileSync('/dev/stdin').toString().split('');
var answer = '';
for(var i=0; i<inputs.length; i++){
    var char = inputs[i].charCodeAt(0);
    if(char>=65 && char<=90){
        var upper = char+13;
        if(upper>90){
            answer += String.fromCharCode(upper-26);
        }else{
            answer += String.fromCharCode(upper);
        }
    }else if(char >= 97 && char <= 122){
        var lower = char+13;
        if(lower >122){
            answer += String.fromCharCode(lower-26);
        }else{
            answer += String.fromCharCode(lower);
        }
    }else if(char === 32){
        answer += ' ';
    }else{
        answer += inputs[i];
    }
}
console.log(answer);
728x90

댓글