6-18 电码加密 分数 10 作者 余贞侠 单位 成都信息工程大学 为防止信息窃取,需要采用加密技术将电文加密变成密文。恺撒密码是一种简单的替换加密技术,其规则是将明文中的所有字母都在字母表上偏移offset位后被替换成密文:当offset大于零时,表示向后偏移;当offset小于零时,表示向前偏移。输入一个以回车符为结束标志的字符串(少于80个字符),再输入一个整数offset,调用函数fun()后用凯撒密码将其加密后输出。 函数接口定义: void fun ( char *Pstr, const
时间: 2023-06-11 10:08:29 浏览: 272
char *Pstr, const int offset) {
int len = strlen(Pstr);
for(int i = 0; i < len; i++) {
if(isalpha(Pstr[i])) { // 判断是否为字母
if(isupper(Pstr[i])) { // 判断是否为大写字母
Pstr[i] = (Pstr[i] - 'A' + offset + 26) % 26 + 'A'; // 加密
} else {
Pstr[i] = (Pstr[i] - 'a' + offset + 26) % 26 + 'a'; // 加密
}
}
}
printf("%s", Pstr); // 输出加密后的字符串
}
相关问题
编程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
好的,下面是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;
}
```
这个程序的思路是先读入一个字符串,然后再读入一个整数偏移量。接着对字符串进行遍历,如果是字母就进行加密,否则不做处理。加密方法是先判断是大写字母还是小写字母,然后用偏移量对字母进行偏移,最后输出加密后的字符串。
7-48* 凯撒密码 分数 20 全屏浏览题目 切换布局 作者 颜晖 单位 浙大城市学院 为了防止信息被别人轻易窃取,需要把电码明文通过加密方式变换成为密文。输入一个以回车符为结束标志的字符串(少于80个字符),再输入一个整数offset,用凯撒密码将其加密后输出。恺撒密码是一种简单的替换加密技术,将明文中的所有字母都在字母表上偏移offset位后被替换成密文,当offset大于零时,表示向后偏移;当offset小于零时,表示向前偏移。 输入格式: 输入第一行给出一个以回车结束的非空字符串(少于80个字符);第二行输入一个整数offset。 输出格式: 输出加密后的结果字符串。c语言
以下是C语言的实现代码:
```c
#include <stdio.h>
#include <string.h>
#define MAX_LEN 80
int main()
{
char str[MAX_LEN + 1];
int offset, len, i;
fgets(str, MAX_LEN + 1, stdin);
len = strlen(str);
if (str[len - 1] == '\n') {
str[len - 1] = '\0';
len--;
}
scanf("%d", &offset);
for (i = 0; i < len; i++) {
if (str[i] >= 'a' && str[i] <= 'z') {
str[i] = 'a' + (str[i] - 'a' + offset + 26) % 26;
} else if (str[i] >= 'A' && str[i] <= 'Z') {
str[i] = 'A' + (str[i] - 'A' + offset + 26) % 26;
}
}
printf("%s\n", str);
return 0;
}
```
首先使用 `fgets()` 函数读入一个字符串,然后判断其长度,如果最后一个字符是回车符就将其替换为字符串结束标志符 `\0`。接着使用 `scanf()` 函数读入一个整数 `offset`,表示偏移量。最后遍历字符串中的每个字符,如果是小写字母就将其偏移 `offset` 位,否则如果是大写字母就同样进行偏移,最后输出加密后的字符串。
阅读全文