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

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

?? 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];//明文左側(cè)的初始化
	for(i=33;i<=64;i++)
		R0[i-32]=m1[i];//明文右側(cè)的初始化
	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++)//循環(huán)左移一位
	{
		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++)      //循環(huán)左移一位
	{
		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++)//循環(huán)左移兩位
	{
		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++)//循環(huán)左移兩位
	{
		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++)//循環(huán)左移兩位
	{
		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++)//循環(huán)左移兩位
	{
		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++)//循環(huán)左移兩位
	{
		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++)//循環(huán)左移兩位
	{
		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++)      //循環(huán)左移一位
	{
		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++)//循環(huán)左移兩位
	{
		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++)//循環(huán)左移兩位
	{
		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++)//循環(huán)左移兩位
	{
		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++)//循環(huán)左移兩位
	{
		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++)//循環(huán)左移兩位
	{
		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++)//循環(huán)左移兩位
	{
		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++)      //循環(huán)左移一位
	{
		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,

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品播放一区二区| 欧美在线综合视频| 欧美极品少妇xxxxⅹ高跟鞋| 91蜜桃婷婷狠狠久久综合9色| 亚洲a一区二区| 中文字幕一区二区三区蜜月| 欧美久久婷婷综合色| 不卡av在线网| 国产一区二区三区四区五区美女| 亚洲一区二区三区四区五区黄| 亚洲精品在线一区二区| 欧美丰满高潮xxxx喷水动漫| 91丝袜高跟美女视频| 国产精品亚洲一区二区三区妖精 | 67194成人在线观看| 国产成人aaa| 狠狠狠色丁香婷婷综合激情| 亚洲成av人片在www色猫咪| 一区免费观看视频| 国产午夜精品久久久久久免费视| 日韩你懂的在线观看| 欧美人伦禁忌dvd放荡欲情| 色婷婷一区二区| 91亚洲国产成人精品一区二区三| 国产成人欧美日韩在线电影| 精品系列免费在线观看| 美女一区二区三区| 秋霞电影一区二区| 亚洲18女电影在线观看| 亚洲第一久久影院| 亚洲综合色视频| 一区二区三区美女视频| 亚洲视频你懂的| 亚洲图片另类小说| 1024亚洲合集| 国产精品白丝在线| 亚洲视频免费观看| 亚洲精品一卡二卡| 一区二区免费在线播放| 一区二区三区不卡视频在线观看 | 午夜私人影院久久久久| 亚洲一区二区三区在线| 一区二区三区中文字幕在线观看| 亚洲色欲色欲www| 一区二区三区 在线观看视频| 亚洲视频每日更新| 亚洲一区二区三区四区五区中文| 亚洲制服丝袜一区| 性久久久久久久久久久久| 日韩电影一区二区三区| 蜜臀av性久久久久蜜臀aⅴ流畅 | 国产99久久久国产精品免费看| 狠狠v欧美v日韩v亚洲ⅴ| 狠狠色丁香婷婷综合| 国产成人综合在线观看| 99久久国产综合精品麻豆| 色综合中文字幕| 欧美福利一区二区| 26uuu精品一区二区在线观看| 国产日韩欧美a| 亚洲精品第1页| 肉色丝袜一区二区| 国内精品第一页| 成人性生交大片免费看中文网站| 99免费精品在线| 欧美男男青年gay1069videost| 91精品国模一区二区三区| 精品国产123| 国产精品丝袜91| 一区二区在线电影| 免费不卡在线视频| 大胆欧美人体老妇| 欧美三级视频在线| 久久久久99精品一区| 亚洲激情一二三区| 久久99日本精品| 不卡欧美aaaaa| 欧美一卡在线观看| 国产精品久久三区| 美女一区二区三区| 91亚洲精品一区二区乱码| 欧美高清www午色夜在线视频| 国产丝袜欧美中文另类| 亚洲成av人片在线| 成人影视亚洲图片在线| 欧美剧在线免费观看网站| 国产亚洲污的网站| 亚洲国产成人av网| 成人精品免费看| 日韩一区二区视频| 亚洲欧美国产三级| 国产精品综合二区| 欧美日本国产视频| 国产精品电影院| 久久草av在线| 欧美亚洲综合色| 国产欧美日本一区二区三区| 日本亚洲三级在线| 一本一道综合狠狠老| 久久久久国色av免费看影院| 日韩一区精品字幕| 91亚洲精品久久久蜜桃网站| 精品成人免费观看| 日本亚洲免费观看| 欧美色图在线观看| 中文字幕在线视频一区| 久久 天天综合| 欧美日本韩国一区二区三区视频| 日韩美女久久久| 国产成人丝袜美腿| 欧美va在线播放| 日日欢夜夜爽一区| 色婷婷av一区二区三区大白胸| 久久午夜国产精品| 久久精品国产色蜜蜜麻豆| 欧美色男人天堂| 亚洲精品国产高清久久伦理二区| 国产成人综合在线| 久久久久久亚洲综合影院红桃| 日韩国产精品久久| 欧美日韩国产123区| 亚洲一区国产视频| 欧美最新大片在线看| 自拍偷在线精品自拍偷无码专区| 成人在线综合网| 国产精品网站在线播放| 国产成人免费视频网站高清观看视频| 欧美精品一区二区在线播放| 美女一区二区视频| 欧美v日韩v国产v| 久久99久久久欧美国产| 欧美mv日韩mv| 黑人精品欧美一区二区蜜桃| 欧美va日韩va| 精品中文字幕一区二区小辣椒| 欧美成人午夜电影| 韩国一区二区视频| 久久亚洲二区三区| 国产成人免费在线| 国产精品成人一区二区三区夜夜夜| 国产成人免费高清| 中文无字幕一区二区三区| 成人黄动漫网站免费app| 国产精品麻豆欧美日韩ww| 不卡的av电影在线观看| **性色生活片久久毛片| 色综合久久久久| 亚洲va欧美va人人爽午夜| 91精品国产日韩91久久久久久| 日韩精品亚洲一区二区三区免费| 91麻豆精品91久久久久同性| 玖玖九九国产精品| 久久精品一区蜜桃臀影院| 国产**成人网毛片九色| 亚洲品质自拍视频网站| 欧美色精品在线视频| 免费高清视频精品| 久久夜色精品国产噜噜av| 成人av动漫在线| 亚洲一区二区欧美日韩| 一区二区三区不卡视频在线观看| 国产精品久久久久久久久图文区| 国产suv精品一区二区三区| 欧美激情中文字幕| 成人国产精品免费网站| 一级中文字幕一区二区| 日韩一区二区三区电影在线观看| 国产在线视视频有精品| 亚洲欧美在线aaa| 欧美日韩亚洲综合在线 | 蜜臂av日日欢夜夜爽一区| 精品精品国产高清一毛片一天堂| 国产福利一区在线| 亚洲午夜在线观看视频在线| 精品免费国产二区三区| 99久久精品免费观看| 伊人婷婷欧美激情| 欧美va天堂va视频va在线| 91麻豆123| 激情综合亚洲精品| 亚洲欧美色综合| 欧美一区二区三区免费在线看| 国产伦精品一区二区三区免费迷| 亚洲日本欧美天堂| 日韩免费看的电影| 色综合天天综合给合国产| 麻豆精品一区二区| 日韩毛片视频在线看| 欧美成人video| 国产日韩一级二级三级| 成人小视频在线| 亚洲午夜久久久久久久久久久| 日韩欧美亚洲国产精品字幕久久久| 成人激情av网| 日本不卡不码高清免费观看| 国产欧美日韩视频一区二区| 欧美喷潮久久久xxxxx| 成人av免费在线观看| 国产在线视视频有精品| 五月天国产精品|