백준 11655번: ROT13
📌 문제
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으로 암호화한 내용을 출력한다.
📝 문제 접근 방법
아이디어
ROT13은 영어 알파벳을 13글자씩 순환 이동시키는 간단한 치환 암호입니다.
알파벳 대문자와 소문자에만 적용하며 숫자와 공백 등은 변환하지 않고 그대로 유지합니다.
- 알파벳 처리
- 알파벳 위치 계산: ord() 함수로 문자에서 아스키 값을 구한 뒤 대문자는 ord('A'), 소문자는 ord('a') 를 빼서 알파벳 내 0 ~ 25 범위의 위치를 계산합니다.
- 13글자 이동: ROT13은 알파벳을 13글자 이동하는 방식으로 현재 위치에 13을 더해 이동한 위치를 계산합니다.
- 순환 처리: 알페벳은 26글자이므로 26을 초과한 값은 %26 으로 나머지를 구해 다시 0부터 시작하도록 만듭니다.
- 다시 문자로 변환: 이동된 위치에 ord('A) 나 ord('a') 를 더해 다시 문자로 변환합니다.
- 알파벳 이외의 문자 처리: 숫자, 공백, 특수문자는 변환하지 않고 그대로 출력합니다.
👩💻 나의 답안
s = list(input())
for elem in s:
if elem.isupper():
print(chr((ord(elem) - ord('A') + 13) % 26 + ord('A')), end="")
elif elem.islower():
print(chr((ord(elem) - ord('a') + 13) % 26 + ord('a')), end="")
else:
print(elem, end="")
'코딩테스트 대비' 카테고리의 다른 글
[파이썬(Python)] 백준 2609번 최대공약수와 최소공배수 (0) | 2024.11.26 |
---|---|
[파이썬(Python)] 백준 11656번 접미사 배열 (0) | 2024.11.18 |
[파이썬(Python)] 백준 10820번 문자열 분석 (0) | 2024.11.16 |
[파이썬(Python)] 백준 10809번 알파벳 찾기 (0) | 2024.11.15 |
[파이썬(Python)] 백준 10808번 알파벳 개수 (0) | 2024.11.15 |