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

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

?? work.cpp

?? DES加密方法加密BMP圖像
?? CPP
?? 第 1 頁 / 共 4 頁
字號:
#include <iostream>
#include <stdio.h>
#include <string>

using namespace std;

#include <math.h>

int K1[49],K2[49],K3[49],K4[49],K5[49],K6[49],K7[49],K8[49],K9[49],K10[49],K11[49],K12[49],K13[49],K14[49],K15[49],K16[49];
int R0[33],L0[33],t1[65],m[65],k[65];

void Encode(void);
void Decode(void);
void initial(void);
void desEncode(void);
void desDecode(void);

void main()
{
	Encode();
	Decode();
}

void Encode(void)
{
	FILE *fp1,*fp2,*fp3;
	unsigned char temp[8];
	int h,i,j,str[8],flag=0,time=0;
	char ch;
	string fp1n;


	cout<<"Input the name of the file you want to encode."<<endl;
	cin>>fp1n;

	fp1=fopen(fp1n.c_str(),"rb");
	fp2=fopen("key.txt","rb");
	fp3=fopen("cipher.bmp","wb");
	
	for(i=0;i<8;i++)     //make k
	{
		ch=fgetc(fp2);
		for(j=0;j<8;j++)
		{
			temp[j]=ch%2;
			ch=ch/2;
		}
		j=i*8;
		j++;
		for(h=7;h>=0;h--,j++)
		{
			k[j]=temp[h];
		}
	}
	for(i=1;i<36;i++)
	{
		for(j=0;j<4;j++)
		{
			temp[0]=fgetc(fp1);
			fputc(temp[0],fp3);
		}
	}
	while(!flag)
	{
		for(i=0;i<8;i++)
		{
			if(!feof(fp1))
			{
				temp[i]=fgetc(fp1);
			}
			else
			{
				flag=1;
				break;
			}
		}
		if(flag)       //Bu Qi 8 Byte
		{
			for(;i<8;i++)
			{
				temp[i]=0;
			}
		}
		for(i=0;i<8;i++)            //make m
		{
			for(j=0;j<8;j++)
			{
				str[j]=temp[i]%2;
				temp[i]=temp[i]/2;
			}
			h=i*8;
			h++;
			for(j=7;j>=0;j--,h++)
			{	
				m[h]=str[j];
			}
		}
		if(time==1)
		{
			for(i=1;i<65;i++)
			{
				m[i]+=t1[i];
				if(m[i]==2)
				{
					m[i]=0;
				}
			}
		}
		initial();
		desEncode();
		for(i=0;i<=7;i++)
		{
			temp[i]=0;
			for(j=8;j>=1;j--)
			{
				temp[i]=temp[i]+t1[i*8+j]*(int)pow(2,8-j);
			}
			fputc(temp[i],fp3);
		}
		time=1;
	}
	
	fclose(fp1);
	fclose(fp2);
	fclose(fp3);
}

void Decode(void)
{
	FILE *fp1,*fp2,*fp3;
	unsigned char temp[8];
	int h,i,j,str[8],flag=0,time=0,jkl[65]={0};
	char ch;
	fp1=fopen("cipher.bmp","rb");
	fp2=fopen("key.txt","rb");
	fp3=fopen("plain.bmp","wb");

	for(i=0;i<8;i++)     //make k
	{
		ch=fgetc(fp2);
		for(j=0;j<8;j++)
		{
			temp[j]=ch%2;
			ch=ch/2;
		}
		j=i*8;
		j++;
		for(h=7;h>=0;h--,j++)
		{
			k[j]=temp[h];
		}
	}
	for(i=1;i<36;i++)
	{
		for(j=0;j<4;j++)
		{
			temp[0]=fgetc(fp1);
			fputc(temp[0],fp3);
		}
	}
	while(!flag)
	{
		for(i=0;i<8;i++)
		{
			if(!feof(fp1))
			{
				temp[i]=fgetc(fp1);
			}
			else
			{
				flag=1;
				break;
			}
		}
		if(flag)       //Bu Qi 8 Byte
		{
			for(;i<8;i++)
			{
				temp[i]=0;
			}
		}
		for(i=0;i<8;i++)            //make m[]
		{
			for(j=0;j<8;j++)
			{
				str[j]=temp[i]%2;
				temp[i]=temp[i]/2;
			}
			h=i*8;
			h++;
			for(j=7;j>=0;j--,h++)
			{	
				m[h]=str[j];
			}
		}
		initial();
		desDecode();
		if(time==1)
		{
			for(i=1;i<65;i++)
			{
				t1[i]+=jkl[i];
				if(t1[i]==2)
				{
					t1[i]=0;
				}
			}
		}
		for(i=0;i<=7;i++)
		{
			for(j=8;j>=1;j--)
			{
				temp[i]=temp[i]+t1[i*8+j]*(int)pow(2,8-j);
			}
			fputc(temp[i],fp3);
		}
		time=1;
		for(i=1;i<65;i++)
		{
			jkl[i]=m[i];
		}
	}

	fclose(fp1);
	fclose(fp2);
	fclose(fp3);
}

void initial(void)//生成明文的IP和密鑰的16個子密鑰
{
	int m1[65],i,k0[57],C[57];
	int C0[29],D0[29],C1[29],D1[29],C2[29],D2[29],C3[29],D3[29],C4[29],D4[29],C5[29],D5[29],C6[29],D6[29],C7[29],D7
		
		[29],C8[29],D8[29],C9[29],D9[29],C10[29],D10[29],C11[29],D11[29],C12[29],D12[29],C13[29],D13[29],C14[29],D14[29],C15[29],D15
		
		[29],C16[29],D16[29];
    int ip[65]={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 PC_1[57]={57,49,41,33,25,17,9,
		1,58,50,42,34,26,18,
		10,2,59,51,43,35,27,
		19,11,3,60,52,44,36,
		63,55,47,39,31,23,15,
		7,62,54,46,38,30,22,
		14,6,61,53,45,37,29,
		21,13,5,28,20,12,4};
	int PC_2[49]={14,17,11,24,1,5,
		3,28,15,6,21,10,
		23,19,12,4,26,8,
		16,7,27,20,13,2,
		41,52,31,37,47,55,
		30,40,51,45,33,48,
		44,49,39,56,34,53,
		46,42,50,36,29,32};
	
	for(i=1;i<=64;i++)
		m1[i]=m[ip[i-1]];
	for(i=1;i<33;i++)
		L0[i]=m1[i];//明文左側的初始化
	for(i=33;i<=64;i++)
		R0[i-32]=m1[i];//明文右側的初始化
	for(i=1;i<57;i++)//生成子密鑰
		k0[i]=k[PC_1[i-1]];
    for(i=1;i<29;i++)
		C0[i]=k0[i];
	for(i=29;i<=56;i++)
		D0[i-28]=k0[i];
    for(i=1;i<28;i++)//循環左移一位
	{
		C1[i]=C0[i+1];
		D1[i]=D0[i+1];
	}
	C1[28]=C0[1];
	D1[28]=D0[1];
	for(i=1;i<=28;i++)
	{
		C[i]=C1[i];
		C[i+28]=D1[i];
	}
	for(i=1;i<=48;i++)
		K1[i]=C[PC_2[i-1]];//生成子密鑰k1
    for(i=1;i<28;i++)      //循環左移一位
	{
		C2[i]=C1[i+1];
		D2[i]=D1[i+1];
	}
	C2[28]=C1[1];
	D2[28]=D1[1];
	for(i=1;i<=28;i++)
	{
		C[i]=C2[i];
		C[i+28]=D2[i];
	}
	for(i=1;i<=48;i++)
		K2[i]=C[PC_2[i-1]];//生成子密鑰k2
	for(i=1;i<27;i++)//循環左移兩位
	{
		C3[i]=C2[i+2];
		D3[i]=D2[i+2];
	}
	C3[27]=C2[1];
	D3[27]=D2[1];
	C3[28]=C2[2];
	D3[28]=D2[2];
	for(i=1;i<=28;i++)
	{
		C[i]=C3[i];
		C[i+28]=D3[i];
	}
	for(i=1;i<=48;i++)
		K3[i]=C[PC_2[i-1]];//生成子密鑰k3
    for(i=1;i<27;i++)//循環左移兩位
	{
		C4[i]=C3[i+2];
		D4[i]=D3[i+2];
	}
	C4[27]=C3[1];
	D4[27]=D3[1];
	C4[28]=C3[2];
	D4[28]=D3[2];
	for(i=1;i<=28;i++)
	{
		C[i]=C4[i];
		C[i+28]=D4[i];
	}
	for(i=1;i<=48;i++)
		K4[i]=C[PC_2[i-1]];//生成子密鑰k4
	for(i=1;i<27;i++)//循環左移兩位
	{
		C5[i]=C4[i+2];
		D5[i]=D4[i+2];
	}
	C5[27]=C4[1];
	D5[27]=D4[1];
	C5[28]=C4[2];
	D5[28]=D4[2];
	for(i=1;i<=28;i++)
	{
		C[i]=C5[i];
		C[i+28]=D5[i];
	}
	for(i=1;i<=48;i++)
		K5[i]=C[PC_2[i-1]];//生成子密鑰k5
	for(i=1;i<27;i++)//循環左移兩位
	{
		C6[i]=C5[i+2];
		D6[i]=D5[i+2];
	}
	C6[27]=C5[1];
	D6[27]=D5[1];
	C6[28]=C5[2];
	D6[28]=D5[2];
	for(i=1;i<=28;i++)
	{
		C[i]=C6[i];
		C[i+28]=D6[i];
	}
	for(i=1;i<=48;i++)
		K6[i]=C[PC_2[i-1]];//生成子密鑰k6
	for(i=1;i<27;i++)//循環左移兩位
	{
		C7[i]=C6[i+2];
		D7[i]=D6[i+2];
	}
	C7[27]=C6[1];
	D7[27]=D6[1];
	C7[28]=C6[2];
	D7[28]=D6[2];
	for(i=1;i<=28;i++)
	{
		C[i]=C7[i];
		C[i+28]=D7[i];
	}
	for(i=1;i<=48;i++)
		K7[i]=C[PC_2[i-1]];//生成子密鑰k7
	for(i=1;i<27;i++)//循環左移兩位
	{
		C8[i]=C7[i+2];
		D8[i]=D7[i+2];
	}
	C8[27]=C7[1];
	D8[27]=D7[1];
	C8[28]=C7[2];
	D8[28]=D7[2];
	for(i=1;i<=28;i++)
	{
		C[i]=C8[i];
		C[i+28]=D8[i];
	}
	for(i=1;i<=48;i++)
		K8[i]=C[PC_2[i-1]];//生成子密鑰k8
	for(i=1;i<28;i++)      //循環左移一位
	{
		C9[i]=C8[i+1];
		D9[i]=D8[i+1];
	}
	C9[28]=C8[1];
	D9[28]=D8[1];
	for(i=1;i<=28;i++)
	{
		C[i]=C9[i];
		C[i+28]=D9[i];
	}
	for(i=1;i<=48;i++)
		K9[i]=C[PC_2[i-1]];//生成子密鑰k9
	for(i=1;i<27;i++)//循環左移兩位
	{
		C10[i]=C9[i+2];
		D10[i]=D9[i+2];
	}
	C10[27]=C9[1];
	D10[27]=D9[1];
	C10[28]=C9[2];
	D10[28]=D9[2];
	for(i=1;i<=28;i++)
	{
		C[i]=C10[i];
		C[i+28]=D10[i];
	}
	for(i=1;i<=48;i++)
		K10[i]=C[PC_2[i-1]];//生成子密鑰k10
	for(i=1;i<27;i++)//循環左移兩位
	{
		C11[i]=C10[i+2];
		D11[i]=D10[i+2];
	}
	C11[27]=C10[1];
	D11[27]=D10[1];
	C11[28]=C10[2];
	D11[28]=D10[2];
	for(i=1;i<=28;i++)
	{
		C[i]=C11[i];
		C[i+28]=D11[i];
	}
	for(i=1;i<=48;i++)
		K11[i]=C[PC_2[i-1]];//生成子密鑰k11
	for(i=1;i<27;i++)//循環左移兩位
	{
		C12[i]=C11[i+2];
		D12[i]=D11[i+2];
	}
	C12[27]=C11[1];
	D12[27]=D11[1];
	C12[28]=C11[2];
	D12[28]=D11[2];
	for(i=1;i<=28;i++)
	{
		C[i]=C12[i];
		C[i+28]=D12[i];
	}
	for(i=1;i<=48;i++)
		K12[i]=C[PC_2[i-1]];//生成子密鑰k12
	for(i=1;i<27;i++)//循環左移兩位
	{
		C13[i]=C12[i+2];
		D13[i]=D12[i+2];
	}
	C13[27]=C12[1];
	D13[27]=D12[1];
	C13[28]=C12[2];
	D13[28]=D12[2];
	for(i=1;i<=28;i++)
	{
		C[i]=C13[i];
		C[i+28]=D13[i];
	}
	for(i=1;i<=48;i++)
		K13[i]=C[PC_2[i-1]];//生成子密鑰k13
	for(i=1;i<27;i++)//循環左移兩位
	{
		C14[i]=C13[i+2];
		D14[i]=D13[i+2];
	}
	C14[27]=C13[1];
	D14[27]=D13[1];
	C14[28]=C13[2];
	D14[28]=D13[2];
	for(i=1;i<=28;i++)
	{
		C[i]=C14[i];
		C[i+28]=D14[i];
	}
	for(i=1;i<=48;i++)
		K14[i]=C[PC_2[i-1]];//生成子密鑰k14
	for(i=1;i<27;i++)//循環左移兩位
	{
		C15[i]=C14[i+2];
		D15[i]=D14[i+2];
	}
	C15[27]=C14[1];
	D15[27]=D14[1];
	C15[28]=C14[2];
	D15[28]=D14[2];
	for(i=1;i<=28;i++)
	{
		C[i]=C15[i];
		C[i+28]=D15[i];
	}
	for(i=1;i<=48;i++)
		K15[i]=C[PC_2[i-1]];//生成子密鑰k15
	for(i=1;i<28;i++)      //循環左移一位
	{
		C16[i]=C15[i+1];
		D16[i]=D15[i+1];
	}
	C16[28]=C15[1];
	D16[28]=D15[1];
	for(i=1;i<=28;i++)
	{
		C[i]=C16[i];
		C[i+28]=D16[i];
	}
	for(i=1;i<=48;i++)
		K16[i]=C[PC_2[i-1]];//生成子密鑰k16
}

void desEncode(void)
{
	int E[49]={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,31};
	int P[33]={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};
	int L1[33],R1[33],L2[33],R2[33],L3[33],R3[33],L4[33],R4[33],L5[33],R5[33],L6[33],R6[33],L7[33],R7[33],L8[33],R8
		
		[33],L9[33],R9[33],L10[33],R10[33],L11[33],R11[33],L12[33],R12[33],L13[33],R13[33],L14[33],R14[33],L15[33],R15[33],L16
		
		[33],R16[33];
	int RE1[49];
	int i,s11[7],s21[7],s31[7],s41[7],s51[7],s61[7],s71[7],s81[7];
	int s1[4][16]={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};
    int s2[4][16]={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};
	int s3[4][16]={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};
	int s4[4][16]={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};
	int s5[4][16]={2,12,4,1,7,10,11,6,8,5,3,15,13,0,14,9,

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本一区中文字幕 | 国产精选一区二区三区| 欧美一卡二卡三卡四卡| 秋霞国产午夜精品免费视频| 日韩欧美一区二区免费| 久久精品国产久精国产| 精品粉嫩超白一线天av| 成人小视频免费在线观看| 国产精品久久免费看| 91福利在线导航| 日韩va亚洲va欧美va久久| 日韩欧美一区二区免费| 国产麻豆日韩欧美久久| 亚洲日本va在线观看| 91久久国产最好的精华液| 五月激情丁香一区二区三区| 日韩精品一区二区三区三区免费 | 亚洲色图欧美在线| 欧美午夜寂寞影院| 精品亚洲免费视频| 中文字幕乱码亚洲精品一区| 欧美亚一区二区| 精品一区二区久久久| 国产精品精品国产色婷婷| 欧美日韩一区三区四区| 国产在线国偷精品免费看| 中文字幕一区二区不卡| 欧美精品丝袜中出| 成人免费观看av| 午夜电影一区二区| 国产视频一区二区在线观看| 在线观看不卡一区| 国产原创一区二区三区| 一区二区三区国产豹纹内裤在线| 日韩精品中午字幕| 91婷婷韩国欧美一区二区| 日韩国产精品久久久久久亚洲| 亚洲国产成人一区二区三区| 欧美日韩国产一级| 国产精品主播直播| 天天色综合天天| 中文av一区二区| 日韩一区二区三区电影在线观看 | 成人av在线影院| 久久精品国产一区二区三| 综合欧美一区二区三区| 亚洲精品一区二区精华| 在线观看亚洲a| 成人蜜臀av电影| 精品一区二区三区影院在线午夜| 一区二区三区四区国产精品| 欧美精品一区男女天堂| 91精品欧美久久久久久动漫| 色欧美乱欧美15图片| 成人禁用看黄a在线| 精品午夜久久福利影院| 午夜久久久久久电影| 亚洲精品欧美专区| 国产精品网曝门| 国产日产欧美一区二区视频| 日韩美女视频一区二区在线观看| 91猫先生在线| 99国产麻豆精品| 高清日韩电视剧大全免费| 久久国产精品99久久久久久老狼 | 首页国产欧美日韩丝袜| 亚洲免费观看高清完整版在线观看熊| 久久久久久麻豆| 欧美mv日韩mv国产| 日韩色视频在线观看| 欧美精选在线播放| 欧美精品在欧美一区二区少妇| 色网站国产精品| 日本久久电影网| 91麻豆精东视频| 99久久99久久精品免费观看| gogo大胆日本视频一区| 成人av免费在线观看| www.日韩精品| av中文字幕在线不卡| 97精品久久久午夜一区二区三区| 波多野结衣91| av亚洲精华国产精华精| caoporn国产一区二区| 99热精品一区二区| 91在线一区二区三区| 91久久线看在观草草青青| 91行情网站电视在线观看高清版| 色噜噜久久综合| 欧美三级在线视频| 在线不卡一区二区| 欧美一区二区免费观在线| 日韩女优电影在线观看| 日韩欧美一二区| 国产三级三级三级精品8ⅰ区| 国产片一区二区三区| 国产精品初高中害羞小美女文| 国产精品成人网| 亚洲午夜久久久久久久久电影院 | 国产精品久久久爽爽爽麻豆色哟哟| 欧美激情在线看| 亚洲精品视频在线观看网站| 午夜精品福利视频网站| 日本不卡的三区四区五区| 国产麻豆欧美日韩一区| 91在线观看地址| 欧美美女一区二区| 久久中文字幕电影| 自拍偷自拍亚洲精品播放| 午夜精品久久一牛影视| 精品亚洲aⅴ乱码一区二区三区| 岛国一区二区在线观看| 欧美在线短视频| 欧美大黄免费观看| 国产精品久久久久影院色老大| 亚洲在线视频网站| 国产一区二区看久久| 色网站国产精品| 26uuu精品一区二区在线观看| 亚洲国产经典视频| 午夜精品影院在线观看| 国产成人av影院| 欧美日韩一区二区在线观看| 久久精品男人天堂av| 亚洲国产美国国产综合一区二区| 狠狠色综合日日| 欧美三日本三级三级在线播放| 久久精品视频一区| 亚洲国产精品影院| 国产成人自拍高清视频在线免费播放| 色综合久久久久综合体| 精品国产乱码久久久久久夜甘婷婷 | 精品国产露脸精彩对白| 亚洲欧美一区二区三区极速播放| 久久精工是国产品牌吗| 欧美三级电影精品| 亚洲欧洲av另类| 极品美女销魂一区二区三区免费| 色综合久久66| 国产午夜亚洲精品午夜鲁丝片| 亚洲1区2区3区4区| 91啦中文在线观看| 欧美国产日韩精品免费观看| 热久久一区二区| 欧美特级限制片免费在线观看| 国产精品久久三| 国产夫妻精品视频| 日韩欧美在线综合网| 偷拍亚洲欧洲综合| 一本久道久久综合中文字幕| 亚洲国产精品二十页| 国产一区二区三区久久久| 678五月天丁香亚洲综合网| 夜夜嗨av一区二区三区中文字幕| 成人晚上爱看视频| 国产欧美视频一区二区| 久久69国产一区二区蜜臀| 欧美高清精品3d| 天堂久久久久va久久久久| 欧美日韩一级视频| 亚洲一二三四在线观看| 一本到不卡免费一区二区| 国产精品久久久久久久久晋中 | 欧美日韩国产小视频| 一区二区三区成人在线视频| 99天天综合性| **性色生活片久久毛片| 99精品国产99久久久久久白柏| 中文字幕一区av| 粉嫩一区二区三区性色av| 亚洲国产成人私人影院tom| 国产精品99精品久久免费| 26uuu亚洲综合色欧美| 韩国中文字幕2020精品| 日韩午夜av电影| 另类小说欧美激情| 精品国产3级a| 精品写真视频在线观看| 久久久久久免费| 成人在线视频一区| 中文字幕一区二区三区四区不卡 | 天堂va蜜桃一区二区三区 | 日韩一区二区电影| 经典三级在线一区| 国产亚洲午夜高清国产拍精品| 国产一区二区三区免费| 中文字幕久久午夜不卡| 99v久久综合狠狠综合久久| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆| 成人h动漫精品| 亚洲伊人伊色伊影伊综合网| 91精品国产黑色紧身裤美女| 麻豆精品一区二区三区| 国产欧美一区在线| 色综合激情五月| 美女久久久精品| 国产日韩欧美不卡| 欧美亚洲动漫制服丝袜| 久久精品99国产精品| 中文字幕成人av|