[BOJ][C++] 백준 11655번 ROT13

Updated:

11655번 ROT13

1. 문제 정보

백준 온라인 저지 [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으로 암호화한 내용을 출력한다.


예제 입력1

Baekjoon Online Judge

예제 출력1

Onrxwbba Bayvar Whqtr

예제 입력2

One is 1

예제 출력2

Bar vf 1

시간 / 메모리 제한

1초 / 256MB


2. 생각

  1. 입력 받은 문자열을 암호화하여 출력하는 문제입니다. 암호화하는 방법은 알파벳을 13글자씩 미는 것입니다.

  2. 알파벳은 26개로 구성되어있습니다.
    따라서 처음 13개는 그대로 13글자씩 (+) 방향으로 밀면 되고 뒤의 13개는 (-) 방향으로 밀면 됩니다.( (+)방향으로 밀 경우 알파벳의 아스키 코드를 벗어납니다. )


3. 소스코드 (C++)


터미널의 입출력 화면 예제1

11655_1

터미널의 입출력 화면 예제2

11655_2 11655_3