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

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

?? vigneardlg.cpp

?? 維吉尼亞密碼的破譯。用VC++作為工具
?? CPP
字號:
// VignearDlg.cpp : implementation file
//

#include "stdafx.h"
#include "Vignear.h"
#include "VignearDlg.h"
#include "math.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

/////////////////////////////////////////////////////////////////////////////
// CVignearDlg dialog
#define M 1000

class sq
{
public:
	int a[M];
	int length;
	

    int f[26];
	void freq();

    float Ic(int n);
	sq()
	{
		int i;
		for(i=0;i<M;i++) a[i]=0;
		length=0;
		for(i=0;i<26;i++) f[i]=0;
	}
};

void sq::freq()
{
	int i,j;
	for(i=0;i<26;i++) f[i]=0;
	for(i=0;i<length;i++)
	{
		for(j=0;j<26;j++)
		{
			if (a[i]==j) f[j]++;
		}
	}
	
}

float sq::Ic(int n)
{
	int i;
	float s=0;
	for(i=0;i<26;i++)
	{
		s+=float(f[i]*(f[i]-1));
	}
	s=s/n/(n-1);
	return s;

}
int ctext[M];
int key[M];
int lth=0;
int keylength;
sq squence;



CVignearDlg::CVignearDlg(CWnd* pParent /*=NULL*/)
	: CDialog(CVignearDlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(CVignearDlg)
	m_edit1 = _T("");
	m_edit2 = _T("");
	m_edit3 = _T("");
	m_edit4 = _T("");
	//}}AFX_DATA_INIT
	// Note that LoadIcon does not require a subsequent DestroyIcon in Win32
	m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}

void CVignearDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CVignearDlg)
	DDX_Control(pDX, IDC_EDIT4, c_edit4);
	DDX_Control(pDX, IDC_EDIT3, c_edit3);
	DDX_Control(pDX, IDC_EDIT2, c_edit2);
	DDX_Control(pDX, IDC_EDIT1, c_edit1);
	DDX_Text(pDX, IDC_EDIT1, m_edit1);
	DDX_Text(pDX, IDC_EDIT2, m_edit2);
	DDX_Text(pDX, IDC_EDIT3, m_edit3);
	DDX_Text(pDX, IDC_EDIT4, m_edit4);
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CVignearDlg, CDialog)
	//{{AFX_MSG_MAP(CVignearDlg)
	ON_WM_PAINT()
	ON_WM_QUERYDRAGICON()
	ON_BN_CLICKED(IDC_BUTTON1, OnButton1)
	ON_BN_CLICKED(IDC_BUTTON2, OnButton2)
	ON_BN_CLICKED(IDC_BUTTON3, OnButton3)
	ON_BN_CLICKED(IDC_BUTTON4, OnButton4)
	ON_BN_CLICKED(IDC_BUTTON5, OnButton5)
	ON_BN_CLICKED(IDC_BUTTON6, OnButton6)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CVignearDlg message handlers

BOOL CVignearDlg::OnInitDialog()
{
	CDialog::OnInitDialog();

	// Set the icon for this dialog.  The framework does this automatically
	//  when the application's main window is not a dialog
	SetIcon(m_hIcon, TRUE);			// Set big icon
	SetIcon(m_hIcon, FALSE);		// Set small icon
	
	// TODO: Add extra initialization here
	
	return TRUE;  // return TRUE  unless you set the focus to a control
}

// If you add a minimize button to your dialog, you will need the code below
//  to draw the icon.  For MFC applications using the document/view model,
//  this is automatically done for you by the framework.

void CVignearDlg::OnPaint() 
{
	if (IsIconic())
	{
		CPaintDC dc(this); // device context for painting

		SendMessage(WM_ICONERASEBKGND, (WPARAM) dc.GetSafeHdc(), 0);

		// Center icon in client rectangle
		int cxIcon = GetSystemMetrics(SM_CXICON);
		int cyIcon = GetSystemMetrics(SM_CYICON);
		CRect rect;
		GetClientRect(&rect);
		int x = (rect.Width() - cxIcon + 1) / 2;
		int y = (rect.Height() - cyIcon + 1) / 2;

		// Draw the icon
		dc.DrawIcon(x, y, m_hIcon);
	}
	else
	{
		CDialog::OnPaint();
	}
}

// The system calls this to obtain the cursor to display while the user drags
//  the minimized window.
HCURSOR CVignearDlg::OnQueryDragIcon()
{
	return (HCURSOR) m_hIcon;
}

void CVignearDlg::OnButton1() 
{
	int i=0;
	int t;
	UpdateData(TRUE);
	c_edit1.GetWindowText(m_edit1);
	while (i<m_edit1.GetLength()) 
	{ 
		t=m_edit1.GetAt(i)-'A';
		if ((t<0)||(t>25)) 
		{
			MessageBox("輸入有錯,每位必須是26個大寫英文字母'A' 到 'Z'!","錯誤!",MB_ICONEXCLAMATION);
			c_edit1.SetFocus();
	        UpdateData(FALSE);
			return;
		}
		else i++;
	}
	i=0;
	while (i<m_edit1.GetLength())
	{
		t=m_edit1.GetAt(i)-'A';
		ctext[i]=t;
		i++;
		
	}
	lth=m_edit1.GetLength();
}



	


void CVignearDlg::OnButton2() 
{
	int i,j,m=2;
	int n;
	float I[M];
	float averI=0;
	double min=1;
	UpdateData(TRUE);   
	m_edit2.Empty();
	UpdateData(FALSE);

	
	if(!lth)
	{
        MessageBox("未輸入密文!請按第一步按鈕輸入確定.",
			       "提示!",MB_ICONINFORMATION);
		
		return;
	}

	while(1)
	{

		for(i=0;i<=m-1;i++)
		{
			n=(int)lth/m;
			squence.length=n;
			for(j=0;j<n;j++)
			{
				squence.a[j]=ctext[i+j*m];
			}
			squence.freq();
            I[i]=squence.Ic(n);
		}
		averI=0;
        for(i=0;i<=m-1;i++)
		{
			averI+=I[i];
		}
		averI=averI/m;
		if (fabs(averI-0.065)<=0.005) break;
		
		else m++;
	}
    keylength=m;
    UpdateData(TRUE);
	m_edit2=m+'0';
	UpdateData(FALSE);


}

void CVignearDlg::OnButton3() 
{
	double p[26]={0.082,0.015,0.028,0.043,0.127,0.022,0.020,0.061,0.070,0.002,0.008,0.040,0.024,
		          0.067,0.075,0.019,0.001,0.060,0.063,0.091,0.028,0.010,0.023,0.001,0.020,0.001};
	int i,j,k,g;
	int n;
	double Mg=0,min=1;

	UpdateData(TRUE);   
	m_edit3.Empty();
	UpdateData(FALSE);

	if(!keylength)
	{
        MessageBox("未知密鑰長度!請按第二步按鈕生成.",
			       "提示!",MB_ICONINFORMATION);
		
		return;
	}
	for(i=0;i<keylength;i++)
	{
			n=(int)lth/keylength;
			squence.length=n;
			for(j=0;j<n;j++)
			{
				squence.a[j]=ctext[i+j*keylength];
			}
			squence.freq();
			min=1;

			for(g=0;g<26;g++)
			{   
				Mg=0;
				for(k=0;k<26;k++)
				{
					Mg+=(p[k]*squence.f[(k+g)%26])/n;
				}
				if(fabs(Mg-0.065)<=0.01) 	
				{
					if(fabs(Mg-0.065)<min)	
					{
						key[i]=g;
						min=fabs(Mg-0.065);
					}
				}
			
			}

	}
	UpdateData(TRUE);
	for(i=0;i<keylength;i++)
	{
		m_edit3+=key[i]+'A';
	}
	UpdateData(FALSE);

}

void CVignearDlg::OnButton4() 
{
	int i,j;
	int n;
	int rest;
	int s=0;

	UpdateData(TRUE);   
	m_edit4.Empty();
	UpdateData(FALSE);

	n=(int)lth/keylength;
	rest=lth%keylength;
    for(j=0;j<keylength;j++) s+=key[j];
    
	if(!s)
	{
        MessageBox("未知密鑰!請按第三步按鈕生成.",
			       "提示!",MB_ICONINFORMATION);
		
		return;
	}


	UpdateData(TRUE);
	for(i=0;i<n;i++)
	{
		for(j=0;j<keylength;j++)
		{
			m_edit4+=(ctext[i*keylength+j]+26-key[j])%26+'a';
		}
	}
	for(j=0;j<rest;j++)
	{
		m_edit4+=(ctext[i*keylength+j]+26-key[j])%26+'a';
	}
	UpdateData(FALSE);

}

void CVignearDlg::OnButton5() 
{
	CString strFileName,t;
	int i;
	UpdateData(TRUE);   
	strFileName="test_";
	CFileDialog dlg(FALSE,"ctext",strFileName, //FALSE為"打開文件"窗口,"ctext"為確定時默認的文件類型
		OFN_HIDEREADONLY|OFN_OVERWRITEPROMPT,
		"初始配置文件(*.ctext)|*.ctext||",NULL);
	dlg.m_ofn.lpstrInitialDir=".\\res";
	if(dlg.DoModal()==IDCANCEL) return;
	strFileName = dlg.GetPathName();

	
	CString Output,temp;
	Output.Empty();

	for (i=0;i<m_edit1.GetLength();i++) Output.Insert(65535,m_edit1.GetAt(i));


	CFile file;
	file.Open(strFileName,CFile::modeCreate|CFile::modeWrite);

	file.Write(Output,Output.GetLength());
	file.Close();

    CVignearDlg::MessageBox("保存完畢!","提示",MB_ICONINFORMATION);

}

void CVignearDlg::OnButton6() 
{
	CString strFileName;
	CFile file;
	int i,j;
	int sum;
	char buffer[1000];
	for(i=0;i<1000;i++) buffer[i]=' ';
	UpdateData(TRUE);   
	m_edit1.Empty();
	UpdateData(FALSE);
	
	CFileDialog dlg(TRUE,"ctext",".ctext", //TRUE為"打開文件"窗口,"ctext"為確定時默認的文件類型
		OFN_HIDEREADONLY|OFN_OVERWRITEPROMPT,
		"初始配置文件(*.ctext)|*.ctext||",NULL);
	dlg.m_ofn.lpstrInitialDir=".\\res";
	if(dlg.DoModal()==IDCANCEL) return;
	strFileName = dlg.GetPathName();

	file.Open(strFileName,CFile::modeRead);
	file.Read(buffer,file.GetLength());
	file.Close();
	
	i=0;
	sum=0;
	while(buffer[i]!=' ')
	{
		i++;
		sum++;
	}
	
    for(j=0;j<sum;j++)
	{
	    m_edit1+=buffer[j];
		
	}
	UpdateData(FALSE);
    
	CVignearDlg::MessageBox("提取完畢!","提示",MB_ICONINFORMATION);

}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久精品人体av艺术| 51精品国自产在线| 美女精品自拍一二三四| 亚洲午夜免费电影| 亚洲视频免费在线观看| 亚洲欧洲日本在线| 亚洲女性喷水在线观看一区| 亚洲国产电影在线观看| 国产精品午夜春色av| 国产精品激情偷乱一区二区∴| 国产女主播在线一区二区| 中文文精品字幕一区二区| 国产精品午夜在线| 亚洲免费在线视频| 亚洲电影第三页| 免播放器亚洲一区| 黄色资源网久久资源365| 国产剧情一区在线| eeuss鲁片一区二区三区在线观看| 国产精一区二区三区| 丁香婷婷综合激情五月色| 99精品久久久久久| 欧美三级韩国三级日本一级| 91麻豆精品国产91久久久更新时间| 5月丁香婷婷综合| 久久婷婷一区二区三区| 国产日韩欧美一区二区三区综合| 日本一区二区三区视频视频| 日韩一区在线播放| 亚洲va欧美va人人爽| 精品一区二区三区久久久| 成人一级片在线观看| 91搞黄在线观看| 日韩一级黄色大片| 久久久久国产精品麻豆| 中文字幕永久在线不卡| 天堂精品中文字幕在线| 国产主播一区二区| 日本韩国一区二区| 久久一区二区三区四区| 亚洲猫色日本管| 久久国产三级精品| 色噜噜狠狠成人中文综合 | 国产精品久久久久影视| 亚洲最色的网站| 国内一区二区视频| 欧美视频一区二区三区| 中文字幕不卡在线播放| 天天操天天色综合| 99久久精品费精品国产一区二区| 欧美精品乱码久久久久久按摩 | 国产精品久久久久久妇女6080| 一区二区在线看| 国产原创一区二区| 在线播放一区二区三区| 国产精品视频一二三区| 免费看欧美女人艹b| 色综合天天狠狠| 国产欧美日韩精品在线| 青草av.久久免费一区| 91黄色免费网站| 中文字幕中文字幕一区| 国产黄色成人av| 日韩欧美国产午夜精品| 午夜视频在线观看一区| 色综合久久久久久久久久久| 国产精品美女一区二区在线观看| 久久精品国产99| 欧美一级日韩一级| 午夜欧美2019年伦理| 色哟哟精品一区| 自拍偷自拍亚洲精品播放| 成人一区在线观看| 国产亚洲福利社区一区| 国内精品第一页| 久久蜜桃一区二区| 极品少妇一区二区| 欧美变态凌虐bdsm| 久久99精品国产| 精品国产露脸精彩对白| 激情欧美一区二区三区在线观看| 欧美一级在线视频| 美日韩一区二区| 精品捆绑美女sm三区| 久久超碰97中文字幕| 欧美大片拔萝卜| 国产乱码精品1区2区3区| 国产丝袜美腿一区二区三区| 国产精品一线二线三线| 欧美国产日韩一二三区| av亚洲精华国产精华精| 一区二区三区欧美在线观看| 欧美日韩国产区一| 久久精品国产**网站演员| 久久久激情视频| 99久久99久久精品免费看蜜桃| 亚洲乱码国产乱码精品精98午夜 | 欧亚一区二区三区| 亚洲动漫第一页| 欧美精品vⅰdeose4hd| 精品一区中文字幕| 中文字幕一区二区三区视频 | 91精品国产综合久久香蕉的特点| 欧美96一区二区免费视频| 久久久久久久国产精品影院| 成人app下载| 午夜精品久久久久久久| 久久蜜桃av一区精品变态类天堂| 成人午夜视频免费看| 亚洲高清免费观看 | 99re视频精品| 天堂蜜桃一区二区三区 | 91在线丨porny丨国产| 亚洲午夜影视影院在线观看| 欧美精品三级在线观看| 亚洲欧美另类小说视频| 秋霞午夜av一区二区三区| 久久色.com| 欧美亚洲国产bt| 国产精品1024| 亚洲第一成人在线| 亚洲国产精品99久久久久久久久| 欧美影片第一页| 成人在线视频一区| 麻豆91在线播放免费| 一区二区三区欧美| 久久精品一区二区| 日韩一区二区三区视频在线观看| 99久久99久久免费精品蜜臀| 国产一区亚洲一区| 午夜欧美2019年伦理| 亚洲精品少妇30p| 国产午夜久久久久| 日韩网站在线看片你懂的| 在线亚洲人成电影网站色www| 国产成人精品免费一区二区| 午夜精品爽啪视频| 亚洲视频在线观看一区| 精品国精品自拍自在线| 欧美精品成人一区二区三区四区| 色婷婷av一区二区三区之一色屋| 国产传媒久久文化传媒| 久久精品国产精品青草| 日本中文字幕一区| 亚洲国产日韩a在线播放| 日韩美女视频19| 亚洲欧美中日韩| 综合电影一区二区三区| 欧美国产亚洲另类动漫| 久久久久国产免费免费 | hitomi一区二区三区精品| 国产精品香蕉一区二区三区| 另类综合日韩欧美亚洲| 热久久久久久久| 奇米影视一区二区三区| 日本美女视频一区二区| 男男gaygay亚洲| 久久99国产精品久久99果冻传媒| 午夜视频在线观看一区| 日本va欧美va瓶| 麻豆91在线播放| 久久疯狂做爰流白浆xx| 激情成人综合网| 成人午夜精品在线| www.成人在线| 在线国产电影不卡| 欧美亚男人的天堂| 91麻豆精品国产无毒不卡在线观看| 欧美一区日本一区韩国一区| 欧美一区二区二区| 国产日韩欧美麻豆| 亚洲日韩欧美一区二区在线| 一区二区在线看| 日韩有码一区二区三区| 麻豆视频观看网址久久| 国产高清不卡二三区| 成a人片亚洲日本久久| 91高清视频免费看| 欧美一二三四在线| 欧美韩日一区二区三区| 亚洲在线观看免费视频| 久久精品国产亚洲aⅴ| 国产一区二区毛片| 色呦呦网站一区| 欧美一区二区三区四区高清| 日本一区二区三区dvd视频在线 | 亚洲国产wwwccc36天堂| 国产在线视频一区二区三区| 成人精品国产一区二区4080| 欧美日韩一区国产| 国产日韩欧美不卡| 亚洲第一二三四区| 不卡一卡二卡三乱码免费网站| 欧美日韩亚洲综合一区| 久久久精品黄色| 天天影视网天天综合色在线播放| 丁香激情综合国产| 8v天堂国产在线一区二区| 欧美国产成人在线| 日韩在线观看一区二区|