Computer Science/Algorithm Problem

백준 알고리즘] 5598 - 카이사르 암호(JOI 2007)

TwinParadox 2017. 10. 23. 02:06
728x90

시간 제한 : 1 초

메모리 제한 : 512 MB



문제

가이우스 율리우스 카이사르(Gaius Julius Caesar)는 고대 로마 군인이자 정치가였습니다. 카이사르는 비밀스럽게 편지를 쓸 때, 'A'를 'D로', 'B'를 'E'로, 'C'를 'F'로... 이런 식으로 알파벳 문자를 3개씩 건너뛰어 적었다고 합니다.


26개의 대문자 알파벳으로 이루어진 단어를 카이사르 암호 형식으로 3문자를 옮겨 겹치지 않게 나열하여 얻은 카이사르 단어가 있습니다. 이 카이사르 단어를 원래 단어로 돌려놓는 프로그램을 작성하세요.


각 문자별로 변환 전과 변환 후를 나타낸 건 아래와 같습니다.


      변환전    A B C D E F G H I J K L M N O P Q R S T U V W X Y Z 

      변환후    D E F G H I J K L M N O P Q R S T U V W X Y Z A B C

예를 들어서, 이 방법대로 단어 'JOI'를 카이사르 단어 형식으로 변환한다면 'MRL'을 얻을 수 있고, 앞의 예와 같은 방법으로 얻은 카이사르 단어 'FURDWLD'를 원래 단어로 고치면 'CROATIA'가 됩니다.






입력

입력은 한 줄로 이루어져 있으며, 그 한 줄엔 대문자 알파벳으로 구성된 단어가 1개 있습니다.


입력받는 단어는 최대 1000자 이하입니다.






출력

출력은 입력받은 카이사르 단어를 원래 단어로 고친 걸 출력하시면 됩니다.






소스코드

#include <iostream>
#include <string.h>
using namespace std;
int main(void)
{
	char arr[1001];
	int len;
	cin >> arr;
	len = strlen(arr);
	for (int i = 0; i < len; i++)
	{
		if (arr[i] - 3 < 'A')
			cout << (char)(arr[i] + 23);
		else
			cout << (char)(arr[i] - 3);
	}
}






Tip


아스키 코드에 대한 기본적인 이해, 영어 문자의 숫자라는 기초적인 지식만 있으면 손 쉽게 풀 수 있다.


728x90
728x90