凯撒密码 - C/C++ 数组及字符串
时间: 2023-12-16 16:05:15 浏览: 235
凯撒密码是一种简单的加密算法,它将明文中的每一个字母都按照一个固定的偏移量进行移位,从而生成密文。在 C/C++ 中,可以使用数组和字符串来实现凯撒密码。
以下是一个简单的凯撒密码加密程序的示例代码:
```c++
#include <stdio.h>
#include <string.h>
void encrypt(char *str, int offset)
{
int len = strlen(str);
for (int i = 0; i < len; i++) {
if (str[i] >= 'a' && str[i] <= 'z') {
str[i] = (str[i] - 'a' + offset) % 26 + 'a';
} else if (str[i] >= 'A' && str[i] <= 'Z') {
str[i] = (str[i] - 'A' + offset) % 26 + 'A';
}
}
}
int main()
{
char str[100];
int offset;
printf("请输入明文:");
scanf("%s", str);
printf("请输入偏移量:");
scanf("%d", &offset);
encrypt(str, offset);
printf("密文为:%s\n", str);
return 0;
}
```
在上面的代码中,我们定义了一个 `encrypt` 函数来进行加密操作。该函数接受两个参数,第一个参数是要加密的字符串,第二个参数是偏移量。在函数中,我们使用了一个循环来遍历字符串中的每一个字符。如果该字符是小写字母,则将其转换成数字 0~25,加上偏移量后再取模,最后再转换成对应的小写字母;如果该字符是大写字母,则同样进行相应的操作。
在 `main` 函数中,我们首先从用户输入中读取明文和偏移量,然后调用 `encrypt` 函数进行加密操作,最后输出加密后的密文。
注意,在实际应用中,凯撒密码很容易被破解,因为它的加密方式非常简单。因此,如果需要更加安全的加密方式,应该使用更加复杂的加密算法。
阅读全文