-
11655. ROT13Baekjoon 2023. 5. 2. 02:38
문제
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을 넘지 않는다.
Baekjoon Online Judge
One is 1
출력
첫째 줄에 S를 ROT13으로 암호화한 내용을 출력한다.
Onrxwbba Bayvar Whqtr
Bar vf 1
에러
더보기const fs = require("fs"); const readFileSyncAdd = "/dev/stdin"; const input = fs.readFileSync(readFileSyncAdd).toString().split(''); var ans = []; for(var i in input) { var str = input[i].toString().split('').map(item => item.charCodeAt()); for(var j in str) { if((str[j] >= 97 && str[j] <= 109) || (str[j] >= 65 && str[j] <= 77)) str[j] += 13; else if(str[j] >= 110 && str[j] <= 122) str[j] = 97+(str[j]-109); else if(str[j] >= 78 && str[j] <= 90) str[j] = 65+(str[j]-77); else if(str[j === 32]) str[j] = ' '; else str[j] = str[j]; str[j] = String.fromCharCode(str[j]); } ans.splice(ans.length, 0, (str.join(''))); } console.log(ans.join(''));
처음에 쓴 코드는 이랬다. str에 input을 또 쪼개서... 그걸 아스키코드로 바꿔서...
map 메서드를 실전에 적용시켜보고 싶다는 생각에 억지로 욱여넣은 것 같다.
숫자는 또 뭐 왜 저렇게 썼는지 모르겠다 (...)
13을 추가했을 때 알파벳 범위 밖으로 나가면 다시 26을 빼주면 된다. 이렇게 간단한 것을... 나는 왜?
const fs = require("fs"); const readFileSyncAdd = "/dev/stdin"; const input = fs.readFileSync(readFileSyncAdd).toString().split(''); var ans = ''; for(var i in input) { var str = input[i].charCodeAt(); if (str>=65 && str <=90) { var up = str + 13; if(up > 90) { ans += String.fromCharCode(up-26); } else { ans += String.fromCharCode(up); } } else if(str >= 97 && str <= 122) { var low = str + 13; if(low > 122) { ans += String.fromCharCode(low-26); } else { ans += String.fromCharCode(low); } } else if(str === 32) { ans += ' '; } else { ans += input[i]; } } console.log(ans);
그래서 한번 수정한 코드가 이것이다. 이것도 사실 굉장히 불필요한 부분이 많다.
if else문은 삼항연산자로 짧게 줄일 수 있을 것이고 str이 공백일 경우의 조건문은 필요없을 것이다.
(어차피 공백이면 그대로 공백을 출력하기 때문에, 그냥 else만 있어도 된다.)
최종 코드는 아래와 같다.
코드
const fs = require("fs"); const readFileSyncAdd = "11655.txt"; const input = fs.readFileSync(readFileSyncAdd).toString().split(''); var ans = ''; for(var i in input) { var str = input[i].charCodeAt(); if (str>=65 && str <=90) { var up = str + 13; up > 90 ? ans += String.fromCharCode(up-26) : ans += String.fromCharCode(up) } else if(str >= 97 && str <= 122) { var low = str + 13; low > 122 ? ans += String.fromCharCode(low-26) : ans += String.fromCharCode(low) } else ans += input[i]; } console.log(ans);
'Baekjoon' 카테고리의 다른 글
10808. 알파벳 개수 (0) 2023.05.07 1935. 후위 표기식2 (0) 2023.05.07 10845. 큐 (0) 2023.05.02 10820. 문자열 분석 (0) 2023.05.02 1157. 단어 공부 (0) 2023.04.09