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;
}