日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

维吉尼亚c语言编码原理,维吉尼亚密码的C语言实现.doc

發布時間:2024/10/5 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 维吉尼亚c语言编码原理,维吉尼亚密码的C语言实现.doc 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

#include void Genkey(int len);

void DenKey();

int main()

{

int len = 0;

int select =0;

while(1)

{

printf("請選擇操作:加密(1);解密(2):退出(3)\n");

scanf("%d",&select);

if(select ==1)//加密操作

{

printf("請輸入密鑰長度\n");

scanf("%d",&len);

Genkey(len);

}

else if(select ==2)//解密操作

{

DenKey();

}

else if(select ==3)

{

exit(0);

}

else

{

printf("輸入有誤!\n");

}

}

return 0;

}

void Genkey(int len)

{

srand((unsigned) time(NULL)); //用時間做種,每次產生隨機數不一樣

int number=0,i=0,j=0,len1;

len1=len;

char ch;

char key1[10000]= "";

char alp[26] = {'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'

};

while(len >0)//隨機生成密鑰

{

number= rand() % 26; //產生0-25的隨機數

key1[i] = alp[number];

len --;

i++;

}

printf("隨機生成的密鑰為:");

while(len1>0)//打印密鑰

{

printf("%c",key1[j]);

j++;

len1--;

}

printf("\n");

int L=strlen(key1);

FILE *fp,*fp1;

int num1[26];

int num2[26];

int m=0;

for(m=0; m<26; m++)

{

num1[m]=0;

num2[m]=0;

}

int al=0,bl=0;

fp=fopen("G:\\1.txt","r");

fp1=fopen("G:\\2.txt","w");

if(fp == NULL)

{

printf("文件打開失敗!");

}

i=0,j=0;

fscanf(fp,"%c",&ch);

while(!feof(fp))

{

if((ch>='a'&&ch<='z')||(ch>='A'&&ch<='Z'))

{

if(ch>='A'&&ch<='Z')

{

al=(int)(ch-'A');

num1[al]++;

fprintf(fp1,"%c",(ch+key1[j%L]-'A'-'A')%26+'A');

bl=(int)((ch+key1[j%L]-'A'-'A')%26);

num2[bl]++;

j++;

}

else

{

al=(int)(ch-'a');

num1[al]++;

fprintf(fp1,"%c",(ch+key1[j%L]-'A'-'a')%26+'A');

bl=(int)((ch+key1[j%L]-'A'-'a')%26);

//printf("%d ",bl);

num2[bl]++;

j++;

}

}

fscanf(fp,"%c",&ch);

}

printf("加密結果請查看文檔!\n");

// printf("%d\n",j);

fclose(fp1);

fclose(fp);

//統計明文密文中各字符的頻率

printf("明文中各字符的頻率(a-z):");

for(m=0; m<26; m++)

{

printf("%.3f%% ",(float)num1[m]/j*100);

if((m%5)==0)

{

printf("\n");

}

}

printf("密文中各字符出現的頻率(a-z):");

for(m=0; m<26; m++)

{

printf("%.3f%% ",(float)num2[m]/j*100);

if((m%5)==0)

{

printf("\n");

}

}

//計算重合指數

int sum =0;

int sum1=0;

for(m=0; m<26; m++)

{

sum=sum+num1[m]*(num1[m]-1);

}

for(m=0; m<26; m++)

{

sum1=sum1+num2[m]*(num2[m]-1);

}

printf("密鑰長度為%d時\n",L);

printf("明文的重合指數為:%.3f%%\n",(float)sum/(j*(j-1))*100);

printf("密文的重合指數為:%.3f%%\n",(float)sum1/(j*(j-1))*100);

}

void DenKey()

{

char key[10000];

char ch,temp;

int L,j=0;

if(getchar()=='\n')

temp=' ';

printf("請輸入密鑰(小寫字母): ");

gets(key);

L=strlen(key);

FILE *fp,*fp1;

fp=fopen("G:\\2.txt","r");

fp1=fopen("G:\\3.txt","w");

if(fp == NULL)

{

printf("文件打開失敗!");

}

else

{

fscanf(fp,"%c",&ch);

while(!feof(fp))

{

if(ch>='A'&&ch<='Z')

{

fprintf(fp1,"%c",(ch-key[j%L]-'A'+'a'+26)%26+'A');

j++;

}

else if(ch>='a'&&ch<='z')

{

fprintf(fp1,"%c",(ch-key[j%L]-'a'+'a'+26)%26+'A');

j++;

}

fscanf(fp,"%c",&ch);

}

printf("解密結果請查看文檔!\n");

fclose(fp1);

fclose(fp);

}

}

四、實驗成績(共5分)

程序設計成績(1分)

實驗結果成績(2分)

實驗報告成績(2分)

總成績

指導教師簽字

日期

與50位技術專家面對面20年技術見證,附贈技術全景圖

總結

以上是生活随笔為你收集整理的维吉尼亚c语言编码原理,维吉尼亚密码的C语言实现.doc的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。