我正在尝试制作简单的加密算法。我的目标是将 abc(可以是任何单词)翻译为 123。然后应用一些函数然后再次翻译为文本,这是我的算法。我有归档问题。我创建未加密。 txt 写在“hello world”中,然后调试程序它正在创建 encrypted.txt,但只是写了 worl d。为什么它不写 hello world。总是取最后一个单词和空格“worl d”,你能帮帮我吗?
编辑 https://www.dropbox.com/s/i3afkm439iv3d0v/last%20form.txt这是我为加密添加 multply 2 和 mod 27 的最后一种形式。它工作得更好。但仍然有问题。里面有“hello world” txt file.its 加密 pjxxcpjxxcpjxxcpjxxcscixhpjxxcqscixhqpjxxc scixh 但它必须是 pjxxc scixh
#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); }