[Baekjoon] 11655 ROT13(파이썬/자바스크립트/NodeJS)
이번 문제는 아래 링크에서 풀어볼 수 있습니다.
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으로 암호화한 내용을 출력한다.
예제 입력 1
Baekjoon Online Judge
예제 출력 1
Onrxwbba Bayvar Whqtr
예제 입력 2
One is 1
예제 출력 2
Bar vf 1
정답 코드
나의 답안
파이썬 Ver.
import sys data = sys.stdin.readline().rstrip() def mySolution(data): result = "" for i in data: idx = ord(i) if 97 <= idx < 110 or 65 <= idx < 78: result += chr(ord(i) + 13) elif 110 <= idx < 123 or 78 <= idx < 91: result += chr(ord(i) - 13) else: result += i return result print("mySolution", mySolution(data))
자바스크립트/NodeJS Ver.const fs = require('fs'); const filePath = process.platform === 'linux' ? '/dev/stdin' : './input.txt'; let input = fs.readFileSync(filePath).toString(); const solution1 = (data) => { let result = ''; for (let i of data) { const idx = i.charCodeAt(); if ((idx >= 97 && idx < 110) || (idx >= 65 && idx < 78)) result += String.fromCharCode(idx + 13); else if ((idx >= 110 && idx < 123) || (idx >= 78 && idx < 91)) result += String.fromCharCode(idx - 13); else result += i; } return result; }; console.log('solution1'); console.log(solution1(input));
조건문에 문자 활용
파이썬 Ver.
import sys data = sys.stdin.readline().rstrip() def answer1(data): result = "" for i in data: if "a" <= i <= "z": result += chr((ord(i) + 13) if i <= "m" else (ord(i) - 13)) elif "A" <= i <= "Z": result += chr((ord(i) + 13) if i <= "M" else (ord(i) - 13)) else: result += i return result print("answer1", answer1(data))
자바스크립트/NodeJS Ver.
const fs = require('fs'); const filePath = process.platform === 'linux' ? '/dev/stdin' : './input.txt'; let input = fs.readFileSync(filePath).toString(); const solution2 = (data) => { let result = ''; for (let i of data) { if (i >= 'a' && i <= 'z') result += String.fromCharCode( i <= 'm' ? i.charCodeAt() + 13 : i.charCodeAt() - 13 ); else if (i >= 'A' && i <= 'Z') result += String.fromCharCode( i <= 'M' ? i.charCodeAt() + 13 : i.charCodeAt() - 13 ); else result += i; } return result; }; console.log('solution2'); console.log(solution2(input));
문제 풀이
아스키 문자표를 활용할 줄 안다면 쉽게 풀 수 있는 문제이다. ord 메서드는 문자를 아스키 코드의 숫자로 바꾸는 메서드이고 chr 메서드는 숫자를 아스키 코드표상의 문자로 바꾸는 메서드이다. 이를 활용하여 m을 기준으로 m보다 앞선 문자라면 아스키 코드 숫자에 더하기 13을, m보다 뒤의 문자라면 아스키 코드 숫자에 빼기 13을 하는 식으로 풀었다.
아스키 코드표를 모르겠다면 파이썬에서는 문자의 선후관계를 조건문에 바로 쓸 수 있다. 아마 이렇게 풀이하는 편이 더 직관적이라서 이해하기 편하지 싶다.
함께 보기
https://jinho-study.tistory.com/622
백준 알고리즘 11655번 ROT13(python)
단순 문자열 문제이다. s = input() res = '' for c in s: if 'a'
jinho-study.tistory.com
https://stepbystep1.tistory.com/10
아스키 코드표(ASCII Table)
아스키 코드표다. 컴퓨터는 문자를 문자로 기억하지 않는다. 그대신 순자로 기억하고 표현한다. 예를 들면 문자 'A'는 65로, 'B'는 66으로 표현한다. 그런데 사람마다 규칙을 개인대로 정하면 자칫
stepbystep1.tistory.com