编程C语言:7-6 电码加密 分数 15 作者 余贞侠 单位 成都信息工程大学 为防止信息窃取,需要采用加密技术将电文加密变成密文。恺撒密码是一种简单的替换加密技术,其规则是将明文中的所有字母都在字母表上偏移offset位后被替换成密文:当offset大于零时,表示向后偏移;当offset小于零时,表示向前偏移。输入一个以回车符为结束标志的字符串(少于80个字符),再输入一个整数offset,用凯撒密码将其加密后输出。 输入格式: 从键盘读入一个字符串(少于80个字符),以回车结束。再读入一个整数offset。 输出格式: 输出加密后的字符串。 输入样例1: Hello Hangzhou 2 输出样例1: Jgnnq Jcpibjqw 输入样例2: a=x+y -1 输出样例2: z=w+x
时间: 2024-02-28 17:57:45 浏览: 118
成都信息工程大学804-气象探测原理2021年考研专业课初试大纲.pdf
好的,下面是C语言的代码实现:
```c
#include <stdio.h>
#include <ctype.h>
#define MAX_LEN 80
int main()
{
char str[MAX_LEN + 1]; // 字符串数组
int offset; // 偏移量
// 读入字符串
fgets(str, MAX_LEN + 1, stdin);
// 读入偏移量
scanf("%d", &offset);
// 加密
for (int i = 0; str[i] != '\0'; ++i) {
if (isalpha(str[i])) { // 如果是字母
char base = islower(str[i]) ? 'a' : 'A'; // 判断是大写字母还是小写字母
str[i] = base + (str[i] - base + offset + 26) % 26; // 加密
}
}
// 输出加密后的字符串
printf("%s", str);
return 0;
}
```
这个程序的思路是先读入一个字符串,然后再读入一个整数偏移量。接着对字符串进行遍历,如果是字母就进行加密,否则不做处理。加密方法是先判断是大写字母还是小写字母,然后用偏移量对字母进行偏移,最后输出加密后的字符串。
阅读全文