码迷,mamicode.com
首页 > 其他好文 > 详细

凯撒密码

时间:2015-08-18 16:13:12      阅读:244      评论:0      收藏:0      [点我收藏+]

标签:

1125: 恺撒密码

Time Limit: 1 Sec  Memory Limit: 128 MB

Description

恺撒生活在充满危险和阴谋的时代. 恺撒面对的最困难的问题是生存. 为了生存, 他决定创造一种密码. 这种密码听起来难以置信, 如果不知

道方法, 没有人可以破解.

你是恺撒军队的一个上尉. 你的工作是解密消息并将之提供给将军. 密码很简单. 对明文的每个字母右移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

输入为至多100组数据. 每组数据有如下格式, 中间无空行.

一组数据有3部分:

起始行 - 单独一行: "START"
密文 - 单独一行, 包含1到200个字符, 组成恺撒的消息.
结束行 - 单独一行: "END"

最后一组输入是单独一行: "ENDOFINPUT".

Output

对每组数据有一行输出. 即恺撒的原始消息.

Sample Input

START
NS BFW, JAJSYX TK NRUTWYFSHJ FWJ YMJ WJXZQY TK YWNANFQ HFZXJX
END
START
N BTZQI WFYMJW GJ KNWXY NS F QNYYQJ NGJWNFS ANQQFLJ YMFS XJHTSI NS WTRJ
END
START
IFSLJW PSTBX KZQQ BJQQ YMFY HFJXFW NX RTWJ IFSLJWTZX YMFS MJ
END
ENDOFINPUT

Sample Output

IN WAR, EVENTS OF IMPORTANCE ARE THE RESULT OF TRIVIAL CAUSES
I WOULD RATHER BE FIRST IN A LITTLE IBERIAN VILLAGE THAN SECOND IN ROME
DANGER KNOWS FULL WELL THAT CAESAR IS MORE DANGEROUS THAN HE

HINT

Source

吉首大学软件学院

 1 #include <stdio.h>
 2 #include <string.h>
 3 int main()
 4 {
 5     char a[202],c[11],d[10];
 6     while(gets(c))
 7     {
 8         if(strcmp(c,"ENDOFINPUT")==0)
 9             return 0;
10         gets(a);
11         gets(d);
12         int n=strlen(a);
13         for(int i=0; i<n; i++)
14         {
15             if(a[i]>=F&&a[i]<=Z)
16             {
17                 printf("%c",a[i]-5);
18             }
19             else if(a[i]>=A&&a[i]<=E)
20             {
21                 printf("%c",a[i]+26-5);
22             }
23             else
24                 printf("%c",a[i]);
25         }
26         printf("\n");
27     }
28     return 0;
29 }

 

凯撒密码

标签:

原文地址:http://www.cnblogs.com/tianmin123/p/4739478.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!