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

? 歡迎來(lái)到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? des算法實(shí)現(xiàn)過(guò)程分析 之 c++.txt

?? DES算法實(shí)現(xiàn)過(guò)程分析 之 C
?? TXT
字號(hào):
#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");
}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日本在线视频| 成人精品国产一区二区4080| 欧美日韩一卡二卡三卡| 午夜精品一区二区三区免费视频| 欧美精品一卡二卡| 精品在线免费观看| 中文字幕中文字幕一区| 91高清在线观看| 麻豆精品视频在线| 久久亚洲二区三区| 成人国产亚洲欧美成人综合网| 亚洲精品中文在线观看| 欧美一区二区三区在线观看视频| 国模一区二区三区白浆| 亚洲欧洲av在线| 91精品国产综合久久婷婷香蕉| 激情综合色播激情啊| 最新日韩在线视频| 91精品国产aⅴ一区二区| 国内欧美视频一区二区| 亚洲免费成人av| 日韩午夜在线观看| 国产成人精品1024| 亚洲第一激情av| 国产女人aaa级久久久级| 91行情网站电视在线观看高清版| 美女在线观看视频一区二区| 国产女人18水真多18精品一级做| 在线观看亚洲精品视频| 久久草av在线| 一区二区三区鲁丝不卡| 欧美精品一区二区高清在线观看 | 成人高清视频在线观看| 婷婷六月综合网| 五月天一区二区三区| 久久婷婷色综合| 精品视频一区三区九区| 岛国av在线一区| 日韩精品一级中文字幕精品视频免费观看| 久久丝袜美腿综合| 欧美美女bb生活片| 91免费版pro下载短视频| 国产精品一二一区| 男人的天堂久久精品| 亚洲一区欧美一区| 中文字幕一区二区三区不卡在线 | 精品无码三级在线观看视频| 亚洲乱码国产乱码精品精的特点| 精品久久久久久无| 欧美男男青年gay1069videost | 国内久久精品视频| 午夜a成v人精品| 亚洲精品综合在线| 国产精品美女一区二区三区| 欧美mv日韩mv| 日韩欧美国产综合| 欧美日韩国产综合一区二区 | 91在线免费播放| 国产剧情一区二区| 韩国毛片一区二区三区| 久久成人18免费观看| 秋霞成人午夜伦在线观看| 亚洲国产日韩精品| 狠狠狠色丁香婷婷综合久久五月| 亚洲国产sm捆绑调教视频| 亚洲精品美国一| 中文字幕一区av| 成人欧美一区二区三区黑人麻豆| 久久精品亚洲国产奇米99| 精品国产青草久久久久福利| 777奇米成人网| 欧美精品一二三四| 欧美日韩国产三级| 欧美一区二区三区四区视频| 这里只有精品免费| 777xxx欧美| 日韩一区二区三| 日韩欧美卡一卡二| 欧美mv和日韩mv国产网站| 欧美成人午夜电影| 精品成人佐山爱一区二区| 久久综合狠狠综合久久综合88| 欧美精品一区二区精品网| 久久精品一二三| 中文字幕av一区二区三区| 国产精品成人免费在线| 亚洲激情图片小说视频| 亚洲国产精品久久人人爱| 日本不卡一二三| 国产一区二区免费在线| 丁香一区二区三区| 色女孩综合影院| 91麻豆精品国产91久久久资源速度 | 欧美国产日本韩| 日韩美女视频一区二区| 亚洲综合自拍偷拍| 青青草97国产精品免费观看无弹窗版 | 精品午夜一区二区三区在线观看| 国产黄色成人av| 91成人免费在线| 日韩一本二本av| 中文一区一区三区高中清不卡| 亚洲久草在线视频| 天堂成人国产精品一区| 国产在线不卡一区| 91网站最新网址| 日韩三级视频在线看| 国产精品免费观看视频| 婷婷久久综合九色综合伊人色| 国精产品一区一区三区mba视频| 暴力调教一区二区三区| 欧美日韩国产大片| 久久男人中文字幕资源站| 一区二区不卡在线播放 | 久久免费看少妇高潮| 亚洲日本免费电影| 久久99精品国产91久久来源| 99视频在线观看一区三区| 91精品婷婷国产综合久久性色| 欧美国产综合色视频| 日日噜噜夜夜狠狠视频欧美人| 国产91精品免费| 91精品国产丝袜白色高跟鞋| 中国色在线观看另类| 日本午夜一本久久久综合| 成人福利电影精品一区二区在线观看 | 日本不卡在线视频| 99精品欧美一区二区三区综合在线| 欧美美女一区二区三区| 中文字幕亚洲电影| 久久国产福利国产秒拍| 91高清在线观看| 国产精品护士白丝一区av| 免费观看在线色综合| 欧美少妇xxx| 日韩理论片网站| 国产激情一区二区三区| 日韩欧美成人一区二区| 亚洲国产成人av| 色成年激情久久综合| 中文字幕亚洲在| 国产成人精品1024| 久久中文字幕电影| 久久精品国产精品亚洲综合| 欧美色爱综合网| 综合久久国产九一剧情麻豆| 国产精品99久久久久久宅男| 337p亚洲精品色噜噜狠狠| 一区二区三区久久久| 色综合色综合色综合| 国产精品不卡一区| 成人黄页毛片网站| 欧美激情一区二区在线| 国产精品乡下勾搭老头1| 精品国产一区二区亚洲人成毛片 | 国产区在线观看成人精品| 久久超级碰视频| 日韩欧美专区在线| 美女高潮久久久| 日韩一级完整毛片| 奇米影视7777精品一区二区| 欧美一区二区在线视频| 免费观看在线色综合| 日韩欧美高清在线| 久久er99热精品一区二区| 日韩欧美一区二区不卡| 91免费国产在线| 亚洲欧美另类小说| 色欧美乱欧美15图片| 亚洲一二三四久久| 欧美女孩性生活视频| 青娱乐精品在线视频| 欧美xxxx在线观看| 国产精品18久久久久久久久| 国产欧美久久久精品影院| 大胆欧美人体老妇| 亚洲另类中文字| 欧美精选午夜久久久乱码6080| 亚洲成a天堂v人片| 日韩精品专区在线影院观看| 国产麻豆视频一区| 国产精品国产三级国产aⅴ中文| 波波电影院一区二区三区| 一区二区三区电影在线播| 欧美日韩国产不卡| 图片区小说区区亚洲影院| 欧美电影免费观看完整版| 黄色成人免费在线| 中文字幕乱码亚洲精品一区| 色婷婷综合视频在线观看| 午夜不卡av在线| 久久精品一区二区三区不卡牛牛| 成人av中文字幕| 亚洲国产成人av好男人在线观看| 欧美一区二区三区在线看| 国产很黄免费观看久久| 亚洲一二三区视频在线观看| 欧美sm美女调教| 91美女视频网站| 蜜臀精品久久久久久蜜臀|