C言語で環形暗号アルゴリズムを実装する方法
C言語による環状暗号化アルゴリズムの実装では次のようなアプローチを取ることができます。
- 暗号化する文字列とキーを入力してください。
- 文字列を文字の配列として格納する。
- ループ変数iを定義し、初期値を0とする。
- 現在の文字と鍵の対応する位置の文字を足して、暗号化された文字を作る。
- 印刷可能範囲(ASCIIコード32~126)を越えた暗号化文字があれば、印刷可能文字の総数(94)を引く。
- 暗号化した文字を配列に戻します。
- 暗号化された文字配列を暗号化された文字列として出力する。
下記で、簡単なC言語での循環暗号化アルゴリズムの実装例を提示します。
#include <stdio.h>
#include <string.h>
#define KEY "key" // 密钥
void circularEncrypt(char *str, const char *key) {
int len = strlen(str);
int keyLen = strlen(key);
for (int i = 0; i < len; i++) {
str[i] += key[i % keyLen]; // 加密操作
if (str[i] > 126) {
str[i] -= 94;
}
}
}
int main() {
char str[100];
printf("请输入待加密的字符串:");
fgets(str, sizeof(str), stdin);
str[strcspn(str, "\n")] = '\0'; // 去掉输入字符串末尾的换行符
circularEncrypt(str, KEY);
printf("加密后的字符串:%s\n", str);
return 0;
}
この例は単なる実装例にすぎないため、実際には追加のセキュリティと境界条件を考慮する必要があるので注意してください。