https://www.acmicpc.net/problem/11655
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
- 풀이
- 이해를 돕기 위한 아스키 코드
- 그냥 아스키코드를 13씩 더하면 됩니다. 주의할 점은 M 이나 m 이후로는 즉, N, n 부터는 아스키 코드를 13 더하면 A, a 가 나오는 게 아닌 [ 과 { 이 나오게 됩니다. 그러므로 M, m을 초과했을 경우 13을 더하는 게 아니라 빼줍니다.
- 공백이나 숫자는 그대로 출력되어야 하므로 경우를 만들어서 그냥 출력되게 구현했습니다. (아스키코드로는 48부터 57까지)
- 공백도 숫자도 m, M 초과도 아닌 경우(else), 그냥 13씩 더해서 밀어주면 됩니다.
본 게시물은 제가 공부한 내용을 올린 글이라 내용이 틀리거나 오류가 있을 수도 있습니다. 만약 그럴 시 jaewonahn1234@gmail.com으로 피드백해주시면 감사하겠습니다.
'SW > 백준' 카테고리의 다른 글
[백준] 11656번: 접미사 배열 (C) (0) | 2022.01.04 |
---|---|
[백준] 10824번: 네 수 (C) (0) | 2022.01.04 |
[백준] 2743: 단어 길이 재기 (C) (0) | 2022.01.04 |
[백준] 10820: 문자열 분석 (C) (0) | 2022.01.04 |
[백준] 10809번: 알파벳 찾기 (C) (0) | 2022.01.04 |