2702:密码翻译

2702:密码翻译

全局题号1704
http://bailian.openjudge.cn/practice/2702/
总时间限制: 1000ms 内存限制: 65536kB
描述
在情报传递过程中,为了防止情报被截获,往往需要对情报用一定的方式加密,简单的加密算法虽然不足以完全避免情报被破译,但仍然能防止情报被轻易的识别.我们给出一种最简的的加密方法,对给定的一个字符串,把其中从a-y,A-Y的字母用其后继字母替代,把z和Z用a和A替代,则可得到一个简单的加密字符串.
输入
第一行是字符串的数目n, (也要使用get(s)读取字符串,再用n=atoi(s)获得整数数值).
其余n行每行一个字符串,用gets(s)方式读取这一行字符串.每个字符串长度小于80个字符.
输出
输出每行字符串的加密字符串.
样例输入
1
Hello! How are you!
样例输出
Ifmmp! Ipx bsf zpv!
提示
为了避免gets和scanf在使用时的冲突,可用n=atoi(s)把字符串s转换为整数.atoi定义在头文件stdlib.h中.
来源
计算概论05

复制代码
 1 #include<stdio.h>
 2 #include<stdlib.h>
 3 void fun(char a[])
 4 {
 5     int i;
 6     for(i=0;a[i]!='\0';i++)
 7     {
 8         if(a[i]>='a'&&a[i]<='z')
 9         {
10             a[i]++;
11             if(a[i]>'z') a[i]='a';
12         }
13         else if(a[i]>='A'&&a[i]<='Z')
14         {
15             a[i]++;
16             if(a[i]>'Z') a[i]='A';
17         }
18     }
19 }
20 int main()
21 {
22     char nStr[50],str[90];
23     int n,i;
24     
25     gets(nStr);
26     n=atoi(nStr);
27     
28     for(i=0;i<n;i++)
29     {
30         gets(str);
31         fun(str);
32         puts(str);
33     }
34     return 0;
35 }
复制代码

 

posted on   华山青竹  阅读(649)  评论(0编辑  收藏  举报

编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 如何调用 DeepSeek 的自然语言处理 API 接口并集成到在线客服系统
· 【译】Visual Studio 中新的强大生产力特性
· 2025年我用 Compose 写了一个 Todo App
历史上的今天:
2014-01-22 归并排序和快速排序【二分法】【资料来自网络】

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示