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

2049: 密码翻译

时间:2019-02-07 12:10:48      阅读:262      评论:0      收藏:0      [点我收藏+]

标签:需要   strlen   nbsp   mis   pre   mem   std   替代   函数   

题目描述

在情报传递过程中,为了防止情报被截获,往往需要对情报用一定的方式加密,简单的加密算法虽然不足以完全避免情报被破译,但仍然能防止情报被轻易的识别。我们给出一种最简的的加密方法,对给定的一个字符串,把其中从a-y,A-Y的字母用其后继字母替代,把z和Z用a和A替代,则可得到一个简单的加密字符串。

输入

可能有多组测试数据。每组测试数据的第一行是字符串的数目n, (也要使用get(s)读取字符串,再用n=atoi(s)获得整数数值),其余n行每行一个字符串,用gets(s)方式读取这一行字符串.每个字符串长度小于80个字符。

输出

 对于每组数据,输出每行字符串的加密字符串。

样例输入

2
fcaweygat5w4yw4yuh6w ytdnhsrth 
eTFWTY!@FE%^FEVCDHGD

样例输出

gdbxfzhbu5x4zx4zvi6x zueoitsui 
fUGXUZ!@GF%^GFWDEIHE


 1 #include<cstdio>
 2 #include<string.h>
 3 int main(){
 4     int n;
 5     scanf("%d",&n);
 6     getchar(); 
 7     while(n--){
 8         char a[100],c[100];
 9         memset(a,\0,sizeof(a));
10         memset(c,\0,sizeof(c));
11         fgets(a,100,stdin);
12         int k=0;
13         for(int i=0;i<strlen(a)-1;i++){
14             if(a[i]>=a&&a[i]<=y||a[i]>=A&&a[i]<=Y){
15                 c[k++]=a[i]+1;
16             }else if(a[i]==z){
17                 c[k++]=a;
18             }else if(a[i]==Z){
19                 c[k++]=A;
20             }
21             else{
22                 c[k++]=a[i];
23             }
24         }
25         printf("%s\n",c);
26     }
27     return 0;
28 } 

Mist Note:fgets函数会读取换行符,所以注意在输入scanf后面添加getchar用来吸收换行符。

2049: 密码翻译

标签:需要   strlen   nbsp   mis   pre   mem   std   替代   函数   

原文地址:https://www.cnblogs.com/mist2019/p/10354564.html

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