“顶嵌杯”----初赛第2题分析

破译密码
据说最早的密码来自于罗马的凯撒大帝。消息加密的办法是:对消息原文中的每个字母,分别用该字母之后的第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部分组成:
  1. 起始行:START
  2. 密码消息:由1到200个字符组成一行,表示凯撒发出的一条消息.
  3. 结束行: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 <stdio.h>
#include <ctype.h>
#include <string.h>
#define SIZE 512
 
int main(void)
{
       int i = 0;
       char s[SIZE];
       while(fgets(s, SIZE-1, stdin) && strncmp(s, "ENDOFINPUT", 10))
           {
               if(! strncmp(s, "START", 5) || ! strncmp(s, "END", 3))
                     continue;
              for(i = 0; s[i] != 0 && i < SIZE; ++i)
              {
                     if (! isupper(s[i]))
                            continue;
                     s[i] -= 5;
                     if (s[i] < 'A')
                            s[i] += 26;
              }
              printf("%s", s);
       }
       return 0;
}
 









本文转自 chen138 51CTO博客,原文链接:http://blog.51cto.com/chenboqiang/271415,如需转载请自行联系原作者
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值