码迷,mamicode.com
首页 > 编程语言 > 详细

凯撒密码C++

时间:2016-11-24 18:31:00      阅读:376      评论:0      收藏:0      [点我收藏+]

标签:put   span   破解   little   mfs   lag   res   else   while   

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

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

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

只有字母需要移位, 其它字符保持不变, 所有字母均是大写.

输入

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

一组数据有3部分:

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

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

输出

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

样例输入

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

样例输出

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

#include <iostream>
#include<stdio.h>
#include<string.h>
using namespace std;
int main()
{
char tmp[256],c;
int i;
while(1)
{
gets(tmp);
if (strcmp(tmp, "ENDOFINPUT") == 0) break;
gets(tmp);
for (i=0; i<strlen(tmp); i++)
{
c=tmp[i];
if (c>=‘A‘ && c<=‘Z‘) putchar((c-‘A‘+21)%26+‘A‘);
else putchar(c);
}
putchar(‘\n‘);
gets(tmp);
}

return 0;
}

凯撒密码C++

标签:put   span   破解   little   mfs   lag   res   else   while   

原文地址:http://www.cnblogs.com/--lr/p/6098417.html

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