天天看點

WEEK11 作業 C - 必做題11-3C - 必做題11-3

C - 必做題11-3

題目描述

Julius Caesar 曾經使用過一種很簡單的密碼。對于明文中的每個字元,将它用它字母表中後 5 位對應的字元來代替,這樣就得到了密文。比如字元’A’用’F’來代替。如下是密文和明文中字元的對應關系。

密文 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

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

你的任務是對給定的密文進行解密得到明文。

你需要注意的是,密文中出現的字母都是大寫字母。密文中也包括非字母的字元,對這些字元不用進行解碼。

Input

一行,給出密文,密文不為空,而且其中的字元數不超過 200。

Output

輸出一行,即密文對應的明文。

輸出時每行末尾的多餘空格,不影響答案正确性

資料範圍

對于 100% 的資料中,1≤n≤20

Sample Input

NS BFW, JAJSYX TK NRUTWYFSHJ FWJ YMJ WJXZQY TK YWNANFQ HFZXJX
           

Sample Output

題解

由題意知,密文轉換成明文的規則是:用密文中的字母在字母表中的往前數第五個字母來代替它。

我們用循環依次讀入檔案中的每個字元,若該字元不是大寫的英文字母,則将其原字母直接輸出;若是大寫英文字母,則用公式

(c-'A'+21)%26+'A'

計算出它對應的明文字母輸出。

代碼

#include <iostream>
#include <stdio.h>
using namespace std;
int main(int argc, char** argv) {
	char c;
	while(scanf("%c",&c)!=EOF){
		if(c>'Z'||c<'A'){printf("%c",c);}
		else{
			printf("%c",(c-'A'+21)%26+'A');
		} 
	}
	return 0;
}