본문 바로가기
Develop/알고리즘

[백준/Python] Bronze I #11655 ROT13

by favorcat 2023. 1. 26.
반응형
 

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으로 암호화한 내용을 출력한다.

풀이

s = list(map(ord,input()))
ans = []
for i in s:
  if 65 <= i <= 90: #대문자
    if i+13 > 90: ans += chr(i+13-26)
    else: ans += chr(i+13)
  elif 97 <= i <= 122: #소문자
    if i+13 > 122: ans += chr(i+13-26)
    else: ans += chr(i+13)
  else: ans += chr(i)

print(''.join(ans))

영어 알파벳만 13글자씩 밀어서 만들어야 하므로, 입력 받을때 바로 ord 함수를 이용하여 저장한다
알파벳인 경우에만 옆으로 13글자를 밀어서 정답 문자열에 추가한다.
옆으로 13글자를 밀었을 때, 값이 벗어나게 된다면, 26을 다시 빼줘서 로테이션을 돌 수 있도록 한다.
알파벳이 대소문자 구분이 있으므로 이를 각각 처리해 준다.

반응형

Comment