DES加密算法源代码

本文详细介绍了DES加密算法的实现过程,包括明文和密钥的预处理、置换表的使用、子密钥生成以及16轮变换的详细步骤。通过源代码的形式,展示了从明文到密文再到解密还原明文的完整流程,帮助读者深入理解DES算法的工作原理。
摘要由CSDN通过智能技术生成

 

 

 

/*DES算法由加密、解密和子密钥的生成三部分组成。*/
#include<iostream.h>
#include<string.h>

//s盒变换,首末两位决定行,中间四位决定列
void dd(int aa[6],int &hang,int &lie)
{
 hang=aa[0]*2+aa[5];
 lie=aa[1]*8+aa[2]*4+aa[3]*2+aa[4];
}

int main()
{  
    /*******************明文及密钥预处理******************/
 int cnt=0;
 char mingwen[9]={"american"};//明文8位 mingwen[9]='/0';
 char key[9]={"cryptogr"};//密钥8位

 int minint[64];//明文
 int keyint[64];//密钥
 int miwen[64];//密文
   
 //明文密文转换为2进制
 int i=0,j=0,m=0,n=0;
 for(i=0;i<64;i++)//用于存储明文化为二进制
  minint[i]=0;
 for(i=0;i<64;i++)//用于存储密钥二进制
  keyint[i]=0;
 for(i=0;i<8;i++)//明文化位2进制
 {
  int temp=(int)mingwen[i];
  int z=0;
  for(z=7;z>=0;z--)
  {
   minint[8*i+z]=temp%2;
   temp=temp/2;
   cnt++;
  }
 }
 for(i=0;i<8;i++)//密钥化位2进制
 {
  int temp=(int)key[i];
  int z;
  for(z=7;z>=0;z--)
  {
   keyint[8*i+z]=temp%2;
   temp=temp/2;
  }
 }


 /***********************置换表***********************/
  
 int pc1[56]={        //pc1 置换表                                      
  56, 48, 40, 32, 24, 16,  8,  0, 57, 49, 41, 33, 25, 17,
  9 ,  1, 58, 50, 42, 34, 26, 18, 10,  2, 59, 51, 43, 35,
  62, 54, 46, 38, 30, 22, 14,  6, 61, 53, 45, 37, 29, 21,
  13,  5, 60, 52, 44, 36, 28, 20, 12,  4, 27, 19, 11, 3};
 int pc2[48]={        //pc2置换表
  13, 16, 10, 23,  0,  4,  2, 27, 14,  5, 20,  9,
  22, 18, 11,  3, 25,  7, 15,  6, 26, 19, 12,  1,
  40, 51, 30, 36, 46, 54, 29, 39, 50, 44, 32, 47,
  43, 48, 38, 55, 33, 52, 45, 41, 49, 35, 28, 31 };

 int beginip[64]={        //初始置换IP
      57,49,41,33,25,17,9,1,  
   59,51,43,35,27,19,11,3,  
   61,53,45,37,29,21,13,5,  
   63,55,47,39,31,23,15,7,  
   56,48,40,32,24,16,8,0,  
   58,50,42,34,26,18,10,2,  
   60,52,44,36,28,20,12,4,  
   62,54,46,38,30,22,14,6 };
 int zhihuanE[48]={  31, 0, 1, 2, 3, 4,
                      3, 4, 5, 6, 7, 8,
                        7, 8, 9,10,11,12,
                       11,12,13,14,15,16,
                

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值