一種常見的C語言字符串加密方法是使用簡單的替換算法,也稱為凱撒密碼。該方法通過將字符串中的每個字符按照固定的偏移量進行替換,從而實現加密和解密。
具體步驟如下:
示例代碼如下:
#include <stdio.h>
#include <string.h>
void encrypt(char* str, int offset) {
int i;
for (i = 0; i < strlen(str); 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("Enter a string: ");
scanf("%s", str);
printf("Enter an offset: ");
scanf("%d", &offset);
encrypt(str, offset);
printf("Encrypted string: %s\n", str);
return 0;
}
注意:這種簡單的替換加密方法并不是十分安全,可以輕易被破解。對于更加安全的加密需求,可以使用更復雜的加密算法,比如AES加密算法。