반응형
문제
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"으로 암호화한 다음 출력하는 프로그램을 작성하시오.
문제풀이
from string import ascii_lowercase, ascii_uppercase
lower = list(ascii_lowercase)
upper = list(ascii_uppercase)
N=input()
chr=""
for i in N:
if(i in lower):
i = lower.index(i)
i = lower[(i+13)%len(lower)]
chr+=i
elif(i in upper):
i = upper.index(i)
i = upper[(i+13)%len(upper)]
chr+=i
else:
chr+=i
print(chr)
- 소문자, 대문자를 각각 리스트로 만든다.
- 이후 입력받은 값을 for문으로 하나씩 입력받아 해당 리스트 안에서 위치를 알아낸다.
- 위치를 바탕으로 13칸을 이동한 값을 i에 다시 저장한 후 결과값에 추가한다.
- 추가된 결과값을 확인한다.
'프로그래밍 > 백준' 카테고리의 다른 글
[알고리즘] 백준 1181 파이썬 - 단어 정렬 (0) | 2022.10.25 |
---|---|
[알고리즘] 백준 10815 파이썬 - 숫자 카드 (0) | 2022.10.24 |
[알고리즘] 백준 10820 파이썬 - 문자열 분석 (0) | 2022.10.22 |
[알고리즘] 백준 9093 파이썬 - 단어 뒤집기 (0) | 2022.10.21 |
[알고리즘] 백준 4375 파이썬 - 1 (3) | 2022.10.20 |