亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? des算法實現過程分析 之 c++.txt

?? DES算法實現過程分析 之 C
?? TXT
字號:
#include <stdio.h>
void expand(const unsigned char in[32],unsigned char out[48])
{
unsigned char table4[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,
                            15, 16, 17, 18, 19, 20, 
                            19, 20, 21, 22, 23, 24, 
                            23, 24, 25, 26, 27, 28,
                            27, 28, 29, 30, 31,  0 };
    for (int i=0;i<48;i++)  out[i]=in[table4[i]]; }

void keys(const unsigned char password[8], unsigned char K[16][48])
{
int i,j;
unsigned char key[64];
                        for (i=0;i<64;i++) {
                            int byte=i/8;
                            int bit=i%8;
                            int value=password[byte];
                            value>>=bit; value&=1;
                            key[i]= value?1:0;
                        }

unsigned char keyT[56];
unsigned char table1[56]={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  };

                         for (i=0; i<56; i++)   keyT[i]=key[table1[i]];

unsigned char *C=keyT;
unsigned char *D=keyT+28;
char loop[16]=      {1, 1, 2, 2, 2, 2, 2, 2, 1, 2, 2, 2, 2, 2, 2, 1};
                            unsigned char tmp[28];
                            int n=loop[i];
                            int j;
                            for (j=0; j<28; j++) tmp[j]=C[(j+28-n)%28];
 
                            for (j=0; j<28; j++) C[j]=tmp[j];
                            for (j=0; j<28; j++) tmp[j]=D[(j+28-n)%28];
 
                            for (j=0; j<28; j++) D[j]=tmp[j];

unsigned char *CD=keyT;
unsigned char table2[48]=
                {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  };
                            for (j=0;j<48;j++)
                                K[i][j]=CD[table2[j]];
    }
}

void des(const unsigned char datain[8], unsigned char dataout[8],
         const unsigned char K[16][48], const unsigned char mode)
{
unsigned char DATA[64];
int i,j;
                        for (i=0;i<64;i++) {
                            int byte=i/8;
                            int bit=i%8;
                            int value=datain[byte];
                            value>>=bit;
                            value&=1;
                            DATA[i]= value;
                        }
unsigned char data[64];
unsigned char table3[64]= { 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 };

                        for (i=0;i<64;i++)  data[i]=DATA[table3[i]];

unsigned char L[17][32];
unsigned char R[17][32];
                        for (i=0; i<32; i++) L[0][i]=data[i];
                        for (i=0; i<32; i++) R[0][i]=data[i+32];

unsigned char s[8][4][16]={
                    /* S[1]          */
    14,  4, 13,  1,  2, 15, 11,  8,  3, 10,  6, 12,  5,  9,  0,  7,
     0, 15,  7,  4, 14,  2, 13,  1, 10,  6, 12, 11,  9,  5,  3,  8,
     4,  1, 14,  8, 13,  6,  2, 11, 15, 12,  9,  7,  3, 10,  5,  0,
    15, 12,  8,  2,  4,  9,  1,  7,  5, 11,  3, 14, 10,  0,  6, 13,
                    /* S[2]          */
    15,  1,  8, 14,  6, 11,  3,  4,  9,  7,  2, 13, 12,  0,  5, 10,
     3, 13,  4,  7, 15,  2,  8, 14, 12,  0,  1, 10,  6,  9, 11,  5,
     0, 14,  7, 11, 10,  4, 13,  1,  5,  8, 12,  6,  9,  3,  2, 15,
    13,  8, 10,  1,  3, 15,  4,  2, 11,  6,  7, 12,  0,  5, 14,  9,
                    /* S[3]          */
    10,  0,  9, 14,  6,  3, 15,  5,  1, 13, 12,  7, 11,  4,  2,  8,
    13,  7,  0,  9,  3,  4,  6, 10,  2,  8,  5, 14, 12, 11, 15,  1,
    13,  6,  4,  9,  8, 15,  3,  0, 11,  1,  2, 12,  5, 10, 14,  7,
     1, 10, 13,  0,  6,  9,  8,  7,  4, 15, 14,  3, 11,  5,  2, 12,
                    /* S[4]          */
     7, 13, 14,  3,  0,  6,  9, 10,  1,  2,  8,  5, 11, 12,  4, 15,
    13,  8, 11,  5,  6, 15,  0,  3,  4,  7,  2, 12,  1, 10, 14,  9,
    10,  6,  9,  0, 12, 11,  7, 13, 15,  1,  3, 14,  5,  2,  8,  4,
     3, 15,  0,  6, 10,  1, 13,  8,  9,  4,  5, 11, 12,  7,  2, 14,
                    /* S[5]          */
     2, 12,  4,  1,  7, 10, 11,  6,  8,  5,  3, 15, 13,  0, 14,  9,
    14, 11,  2, 12,  4,  7, 13,  1,  5,  0, 15, 10,  3,  9,  8,  6,
     4,  2,  1, 11, 10, 13,  7,  8, 15,  9, 12,  5,  6,  3,  0, 14,
    11,  8, 12,  7,  1, 14,  2, 13,  6, 15,  0,  9, 10,  4,  5,  3,
                    /* S[6]          */
    12,  1, 10, 15,  9,  2,  6,  8,  0, 13,  3,  4, 14,  7,  5, 11,
    10, 15,  4,  2,  7, 12,  9,  5,  6,  1, 13, 14,  0, 11,  3,  8,
     9, 14, 15,  5,  2,  8, 12,  3,  7,  0,  4, 10,  1, 13, 11,  6,
     4,  3,  2, 12,  9,  5, 15, 10, 11, 14,  1,  7,  6,  0,  8, 13,
                    /* S[7]          */
     4, 11,  2, 14, 15,  0,  8, 13,  3, 12,  9,  7,  5, 10,  6,  1,
    13,  0, 11,  7,  4,  9,  1, 10, 14,  3,  5, 12,  2, 15,  8,  6,
     1,  4, 11, 13, 12,  3,  7, 14, 10, 15,  6,  8,  0,  5,  9,  2,
     6, 11, 13,  8,  1,  4, 10,  7,  9,  5,  0, 15, 14,  2,  3, 12,
                    /* S[8]          */
    13,  2,  8,  4,  6, 15, 11,  1, 10,  9,  3, 14,  5,  0, 12,  7,
     1, 15, 13,  8, 10,  3,  7,  4, 12,  5,  6, 11,  0, 14,  9,  2,
     7, 11,  4,  1,  9, 12, 14,  2,  0,  6, 10, 13, 15,  3,  5,  8,
     2,  1, 14,  7,  4, 10,  8, 13, 15, 12,  9,  0,  3,  5,  6, 11  };

unsigned char R_[48];
                        for (i=0; i<16; i++) {
                            expand(R[i],R_);
                            for (j=0;j<48;j++)
                                if (mode) R_[j]^=K[i][j];
                                else R_[j]^=K[16-1-i][j];
unsigned char B[8];
                            for (j=0; j<8; j++){    B[j]=0;
                                for (int k=0; k<6; k++)
                                    B[j]|=(R_[j*6+k]<<(6-1-k));}
                            for (j=0; j<8; j++){
                                int m=0; int n=0;
                                m|=(B[j]&0x1); m|=((B[j]>>4)&0x2);
                                n=(B[j]>>1); n&=0x0f;
                                B[j]=s[j][m][n];
                               }   
                            unsigned char tmp[32];
                            for (j=0;j<32; j++)
                                tmp[j]= (B[j/4]>> (4-1-(j%4)))&1;

unsigned char table5[32]={   
                            15,  6, 19, 20, 28, 11, 27, 16,
                             0, 14, 22, 25,  4, 17, 30,  9,
                             1,  7, 23, 13, 31, 26,  2,  8,
                            18, 12, 29,  5, 21, 10,  3, 24};
unsigned char tmp1[32];
                            for (j=0;j<32;j++)
                                tmp1[j]=tmp[table5[j]]; 
                            for (j=0;j<32;j++)
                                R[i+1][j]=L[i][j]^tmp1[j];
                            for (j=0;j<32;j++)
                                L[i+1][j]=R[i][j];
                    }
unsigned char tmp2[64];
                    for (i=0;i<32;i++) tmp2[i]=R[16][i];
                    for (i=32;i<64;i++)tmp2[i]=L[16][i-32];
unsigned char out[64];
                    for (i=0;i<64;i++) out[table3[i]]=tmp2[i];
                    for (i=0; i<8;i++){
                        dataout[i]=0;
                        for (j=0; j<8; j++)
                            dataout[i]|=(out[i*8+j]<<j);}
}
void main()
{
    unsigned char KEY[8]=   "12345678";
    unsigned char source[8]="abcdefgh";
    unsigned char target[8];
    unsigned char K[16][48];

    keys(KEY,K);

    printf("======================");
    printf("\nPassword=%s\n",KEY);
    printf("\nSource     ");
    for (int i=0;i<8;i++)
        printf("%02X ",source[i]&0x0ff);
    printf("\n           ");
    for (i=0;i<8;i++)
        printf("%c  ",source[i]);

#define ENCRYPT 1
    des(source, target,K,ENCRYPT);

    printf("\nEncrypt    ");
    for (i=0;i<8;i++)
        printf("%02X ",target[i]&0x0ff);
    printf("\n           ");
    for (i=0;i<8;i++)
        printf("%c  ",target[i]);

#define DECRYPT 0
    des(target,source, K,DECRYPT);
    printf("\nDecrypt    ");
    for (i=0;i<8;i++)
        printf("%02X ",source[i]&0x0ff);
    printf("\n           ");
    for (i=0;i<8;i++)
        printf("%c  ",source[i]);
    printf("\n");
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩一区久久| 成人国产精品免费观看视频| 7777精品伊人久久久大香线蕉完整版| 亚洲国产综合91精品麻豆| 欧洲一区二区av| 日韩国产欧美在线播放| 日韩三级在线免费观看| 久久99国产精品久久99果冻传媒| 欧美不卡在线视频| 国产成人午夜电影网| 亚洲人成7777| 777xxx欧美| 国产美女久久久久| 一区二区成人在线视频| 91精品国产91久久久久久最新毛片 | 亚洲午夜精品网| 宅男噜噜噜66一区二区66| 麻豆成人在线观看| 中文字幕第一区综合| 欧美视频在线观看一区二区| 日韩国产在线一| 中文字幕不卡的av| 欧美精品 日韩| 国产99久久久精品| 亚洲图片欧美一区| 日本一区二区免费在线| 色综合久久久久综合体桃花网| 日本女优在线视频一区二区| 国产精品久久久爽爽爽麻豆色哟哟| 在线这里只有精品| 国产麻豆精品在线观看| 亚洲国产成人av网| 久久精品亚洲精品国产欧美kt∨ | 成人综合在线网站| 99精品视频在线观看| 亚洲国产成人91porn| 国产日韩精品一区| 欧美日韩日日摸| 91在线视频播放地址| 精品一区二区影视| 一区二区三区在线免费播放| 久久久蜜桃精品| 91精品国产麻豆| 日本高清不卡一区| 成人的网站免费观看| 看片网站欧美日韩| 日韩在线卡一卡二| 一级精品视频在线观看宜春院| 久久久久久亚洲综合| 欧美一区二区三区成人| 91亚洲精品乱码久久久久久蜜桃 | 五月婷婷久久综合| 亚洲激情中文1区| 中文字幕 久热精品 视频在线| 欧美一区二区在线视频| 色婷婷国产精品久久包臀| 国产成人免费视频| 国产毛片精品视频| 久久精品国产一区二区三区免费看 | 国产欧美一区二区精品久导航| 日韩一区二区在线看| 欧美日韩一区二区欧美激情| 色婷婷综合久久久中文字幕| 成人黄色免费短视频| 国产999精品久久| 国产91丝袜在线18| 国产91色综合久久免费分享| 国产毛片精品一区| 国产精品1024| 国产精品亚洲人在线观看| 韩国三级电影一区二区| 麻豆国产91在线播放| 极品尤物av久久免费看| 久久精品国产澳门| 国产伦理精品不卡| 国产91精品精华液一区二区三区 | 国产女主播一区| 国产日韩精品一区二区三区| 国产亚洲精品bt天堂精选| 久久色在线视频| 久久久久国产精品免费免费搜索| 337p粉嫩大胆色噜噜噜噜亚洲 | 91精品国产福利| 日韩精品在线看片z| 精品88久久久久88久久久| 精品国产不卡一区二区三区| 337p日本欧洲亚洲大胆色噜噜| 久久久久久久久久久久久女国产乱 | 天天av天天翘天天综合网色鬼国产 | 美女网站色91| 国产一区二区伦理片| 成人免费看黄yyy456| 91在线视频网址| 欧美精品一二三区| 欧美成人三级在线| 国产精品系列在线| 亚洲精品日日夜夜| 图片区小说区国产精品视频 | 国产精品99精品久久免费| 成人avav在线| 欧美日韩黄色一区二区| 精品国产免费视频| 亚洲欧美怡红院| 日日夜夜精品视频天天综合网| 九九视频精品免费| 99re在线精品| 日韩一区二区高清| 中文字幕一区二区三区蜜月| 香蕉成人伊视频在线观看| 久久不见久久见免费视频1| 成人黄色一级视频| 91精品国模一区二区三区| 中文字幕av资源一区| 天天影视色香欲综合网老头| 国产一区二区三区精品欧美日韩一区二区三区 | 成a人片国产精品| 欧美美女直播网站| 欧美国产日产图区| 日韩电影在线免费看| 国产99久久久国产精品免费看| 欧美伊人久久久久久久久影院| 精品av久久707| 亚洲成人综合视频| 成人自拍视频在线| 日韩久久久久久| 一区二区三区在线视频观看58| 激情综合网av| 欧美在线制服丝袜| 国产亚洲综合在线| 亚洲五码中文字幕| 99久久免费国产| www精品美女久久久tv| 亚洲午夜久久久久久久久电影院| 国产美女视频一区| 日韩视频123| 午夜日韩在线观看| 97aⅴ精品视频一二三区| 国产三级精品视频| 日韩精品五月天| 欧美影片第一页| 亚洲视频你懂的| 成人黄色一级视频| 国产欧美精品在线观看| 奇米色777欧美一区二区| 欧美日韩一区不卡| 亚洲欧美日韩国产成人精品影院| 国产激情精品久久久第一区二区 | 欧美日韩综合色| 一区二区三区中文字幕精品精品| 国产成人h网站| 久久精品日产第一区二区三区高清版| 97国产一区二区| 久久精品一区二区三区不卡牛牛| 蜜臀av在线播放一区二区三区| 欧美视频一区二区三区| 一区二区三区国产| 在线中文字幕一区| 亚洲最大色网站| 在线观看亚洲一区| 亚洲最色的网站| 91传媒视频在线播放| 亚洲乱码国产乱码精品精可以看| 99久久国产免费看| 亚洲欧美日韩电影| 在线观看一区不卡| 五月婷婷激情综合| 欧美一区二区播放| 激情综合色播激情啊| 久久午夜国产精品| 成人av网站在线观看免费| 国产精品免费视频一区| 成人99免费视频| 亚洲精品成人悠悠色影视| 欧美主播一区二区三区美女| 亚洲精品免费电影| 欧美日韩国产成人在线免费| 午夜精品在线看| 91精品国产综合久久久久久漫画| 肉色丝袜一区二区| 久久五月婷婷丁香社区| 成人小视频免费观看| 亚洲日本丝袜连裤袜办公室| 欧洲色大大久久| 天堂久久一区二区三区| 欧美成人激情免费网| 成人午夜视频免费看| 亚洲男人的天堂av| 91精品在线麻豆| 国产东北露脸精品视频| 自拍偷拍欧美激情| 欧美欧美欧美欧美首页| 精品中文av资源站在线观看| 国产精品丝袜一区| 欧美日韩在线不卡| 国产在线精品免费av| 亚洲精品菠萝久久久久久久| 欧美一区二区三区免费在线看| 国产精品一二三区| 亚洲国产成人va在线观看天堂| 精品毛片乱码1区2区3区|