Thursday, April 28, 2016

WRITE A PROGRAM FOR DATA ENCRYPTION STANDARD (DES).

WRITE A PROGRAM FOR DATA ENCRYPTION STANDARD (DES).

#include<stdio.h>
#include<conio.h>
#include<string.h>

void cipher(int p,int c);
int findmin();
void makearray(int,int);
char arr[22][22],darr[22][22],emessage[111],msg[111];
char key[55];
char temp[55],temp2[55];
int k=0,k2,a;

void main()
{
char *message;
int i,j,klen,emlen,flag=0;
int r,c,index,rows;
clrscr();
printf("Enter key: ");
gets(key);
printf("Enter message : ");
gets(message);
strcpy(temp,key);
klen=strlen(key);
k=0;
for(i=0;;i++)
{
if(flag==1)
break;
for(j=0;key[j]!=NULL;j++)
{
if(message[k]==NULL)
{
flag=1;
arr[i][j]=' ';
}
else
{
arr[i][j]=message[k++];
}
}
}
r=i;
c=j;
for(i=0;i<r;i++)
{
for(j=0;j<c;j++)
{
printf("%c",arr[i][j]);
}
printf("\n");
}
k=0;
for(i=0;i<klen;i++)
{
index=findmin();
cipher(index,r);
}
emessage[k]='\0';
printf("\n Encrypted message : ");
for(i=0;emessage[i]!=NULL;i++)
printf("%c",emessage[i]);

printf("\nEnter Key for Mono-Ecry: ");
scanf("%d",&k2);
strcpy(msg,emessage);
for(i=0;i<strlen(msg);i++)
{
a=msg[i];
a=a+k2;
msg[i]=a;
}
msg[i]='\0';
printf("\n\n\tEncrypted Message by MONO : %s\n",msg);

printf("\n\nDecrypt OF MONO\n");
for(i=0;i<strlen(msg);i++)
{
a=msg[i];
a=a-k2;
msg[i]=a;
}
msg[i]='\0';
printf("\n\n\tDecrypted Message by MONO : %s\n",msg);

strcpy(emessage,msg);
emlen=strlen(emessage);
strcpy(temp,key);
rows=emlen/klen;
j=0;
for(i=0,k=1;emessage[i]!=NULL;i++,k++)
{
temp2[j++]=emessage[i];
if(k%rows==0)
{
temp2[j]='\0';
index=findmin();
makearray(index,rows);
j=0;
}
}
printf("Final Decrypted Data @ Rec. side: ");
k=0;
for(i=0;i<r;i++)
{
for(j=0;j<c;j++)
{
printf("%c",darr[i][j]);
}
printf("\n");
}
getch();
}

void cipher(int i,int r)
{
int j;
for(j=0;j<r;j++)
{
emessage[k++]=arr[j][i];
}
}

void makearray(int col,int row)
{
int i,j;
for(i=0;i<row;i++)
darr[i][col]=temp2[i];
}

int findmin()
{
int i,j,min,index;
min=temp[0];
index=0;
for(j=0;temp[j]!=NULL;j++)
{
if(temp[j]<min)
{
min=temp[j];
index=j;
}
}
temp[index]=123;
return(index);
}

No comments:

Post a Comment