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 M 

原文字母: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。

输出:

每个数据集对应一行,是凯撒的原始消息。

n 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

n 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

 

代码:

 

#include <stdio.h>
#include <stdlib.h>
#include <ctype.h>
#include <string.h>
#define MAXLINE 1000
void decipher(const char *cipher, char *text);

int main(int argc, char *argv[])
{
    FILE *fin = fopen("intext.txt", "r");
    FILE *fout = fopen("outtext.txt", "w");
    if(fin == NULL || fout == NULL)
        return EXIT_FAILURE;
    char line[MAXLINE+1] = "";
    char text[MAXLINE+1] = "";
    while (fgets(line, MAXLINE, fin) != NULL) {
        if (strcmp(line, "START\n") == 0) {
            fgets(line, MAXLINE, fin);
            printf("%s", line);getchar();
            decipher(line, text);
            fprintf(fout, "%s", text);
            if (fgets(line, MAXLINE, fin) == NULL)
                perror("fgets error");
            if (strcmp(line, "END\n") != 0) {
                printf("not match END\n");
                return EXIT_FAILURE;
            }
        } else if (strcmp(line, "ENDOFINPUT") == 0) {
            printf("cophertext is end\n");
            return EXIT_SUCCESS;
        } else {
            printf("unknow text\n");
            return EXIT_FAILURE;
        }
    }
    return 0;
}

void decipher(const char *cipher, char *text)
{
    size_t j = 0;
    for (size_t i = 0; cipher[i] != '\0'; ++i) {
        if (isupper(cipher[i])) {
            if (cipher[i] >= 'E') text[j++] = cipher[i] - 5;
            else text[j++] = 'Z' - (4 - (cipher[i] - 'A'));
        } else {
            text[j++] = cipher[i];
        }
    }
    text[j] = '\0';
}


输入文件是:intext.txt

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


输出文件是:outtext.txt

  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


 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值