728x90
https://www.acmicpc.net/problem/11655
문제 설명
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"으로 암호화한 다음 출력하는 프로그램을 작성하시오.
풀이 과정
- 나의 풀이
# 11655 ROT13
import sys
text = sys.stdin.readline()
result = ''
for i in text :
if i.isupper() :
num = ord(i) + 13
if num > 90 :
num -= 26
result += chr(num)
elif i.islower() :
num = ord(i) + 13
if num > 122 :
num -= 26
result += chr(num)
else :
result += i
print(result)
아스키코드표를 이용해서 문제 조건을 만족시켰다.
포인트는 아무래도... 리스트 안에 문자열을 두고 join함수를 쓰는 방식이 아닌 문자열에 += 을 통해 더해준 것..!!
후기
구현 및 정렬문제에서 아스키코드표가 유용한듯.
'Algorithm' 카테고리의 다른 글
[백준] 10808 알파벳 개수 (파이썬 Python) (0) | 2021.08.16 |
---|---|
[백준] 10820 문자열 분석 (Python 파이썬) (0) | 2021.08.11 |
[백준] 1406 에디터 (파이썬 Python) (0) | 2021.07.17 |
[백준] 11718 그대로 출력하기 파이썬(Python) (0) | 2021.07.10 |
[백준] 1935 후위 표기식2 (파이썬 Python) (0) | 2021.07.10 |