私は単純な暗号化アルゴリズムを作成しようとしています。私の目的はabc(任意の単語)を123に翻訳することです。次に、いくつかの関数を適用してから、もう一度テキストに翻訳します。これが私のアルゴリズムです。ファイリングに問題があります。暗号化されていないものを作成します。 「helloworld」内に書かれているtxtは、encrypted.txtを作成しているが、worl dを書いているだけのデバッグプログラムです。なぜ、helloworldを書いていません。常に最後の単語とスペース「world」を取ります。
https://www.dropbox.com/s/i3afkm439iv3d0v/last%20form.txtを編集 します。これは、暗号化のために複数の2とmod27を追加した最後のフォームです。 txtfile.its暗号化pjxxcpjxxcpjxxcpjxxcscixhpjxxcqscixhqpjxxcscixhですが、pjxxcscixhである必要があります
#include <cstdlib>
#include <iostream>
#include<stdio.h>
#include<string.h>
#include <conio.h>
int main()
{
int g,p,sak,v,r,t,z,o,c,l,i,j,k,*D;
char alfabe[27]={'a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z','\0'};
FILE *fp1;
FILE *mat;
char word[20];
fp1 = fopen("unencrypted.txt","r");
do {
g = fscanf(fp1,"%s",word); /* dosyadan bir kelime oku... */
if (g != EOF) {
mat=fopen("encrypted.txt","w") ;
c=strlen(word);
printf("has %d letters ", c);
D = (int *) malloc( sizeof(int)*c );
for(i=0;i<c;i++) {
for(j=0;j<26;j++) {
if(word[i]==alfabe[j]) {
D[i]=(j+1);
break;
}
}
}
printf("\nlast form before translation ");
for(l=0;l<c;l++) {
printf("%d",D[l]); /*it s just for control */
}
for(z=0;z<c;z++){
o=D[z];
word[z]=alfabe[o-1] ; }
printf("\nnew form of word: ");
for(k=0;k<c;k++) {
fprintf(mat," %c",word[k]);
}
fclose(mat);
}
} while (g != EOF);
fclose(fp1); }