des加密算法c语言源代码.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
#includeiostream.h int IP[64] = { 58,50,42,34,26,18,10,2, 60,52,44,36,28,20,12,4, 62,54,46,38,30,22,14,6, 64,56,48,40,32,24,16,8, 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 }; int IP_1[64] = { 40,8,48,16,56,24,64,32, 39,7,47,15,55,23,63,31, 38,6,46,14,54,22,62,30, 37,5,45,13,53,21,61,29, 36,4,44,12,52,20,60,28, 35,3,43,11,51,19,59,27, 34,2,42,10,50,18,58,26, 33,1,41,9,49,17,57,25 }; int E[48] = { 32,1, 2, 3, 4, 5, 4, 5, 6, 7, 8, 9, 8, 9, 10,11,12,13, 12,13,14,15,16,17, 16,17,18,19,20,21, 20,21,22,23,24,25, 24,25,26,27,28,29, 28,29,30,31,32,1 }; int P[32]={16 ,7 , 20 , 21 , 29,12 ,28 , 17 , 1, 15 ,23 , 26 , 5, 18 ,31 , 10 , 2, 8 , 24 , 14 , 32,27, 3 , 9 , 19,13, 30 , 6 , 22,11 ,4 , 25 }; void Char_to_Int(unsigned char in[],int out[],int len) { for(int i=0;ilen;i++) out[i]=int(in[i]); } void Int_to_Char(int in[],unsigned char out[],int len) { for(int i=0;ilen;i++) out[i]=char(in[i]); } void B_to_H(int in[],unsigned char out[]) { for(int i=0;i16;i++) { int temp=in[i*4]*8+in[i*4+1]*4+in[i*4+2]*2+in[i*4+3]; switch(temp) { case 10 :out[i]=A;break; case 11 :out[i]=B;break; case 12 :out[i]=C;break; case 13 :out[i]=D;break; case 14 :out[i]=E;break; case 15 :out[i]=F;break; default :out[i]=unsigned char(temp+48);break; } } } void H_to_B(unsigned char in[],int out[]) { for(int i=0;i16;i++) switch(in[i]) { case A:out[i*4]=1;out[i*4+1]=0;out[i*4+2]=1;out[i*4+3]=0;break; case B:out[i*4]=1;out[i*4+1]=0;out[i*4+2]=1;out[i*4+3]=1;break; case C:out[i*4]=1;out[i*4+1]=1;out[i*4+2]=0;out[i*4+3]=0;break; case D:out[i*4]=1;out[i*4+1]=1;out[i*4+2]=0;out[i*4+3]=1;break; case E

文档评论(0)

anma + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档