密碼演算法 |
|
jackkcg
站務副站長 發表:891 回覆:1050 積分:848 註冊:2002-03-23 發送簡訊給我 |
窮舉密碼演算法
//*******************************************************************
//在許多情況下我們需要窮舉組合的演算法,比如密碼詞典。
//這個演算法的關鍵是密碼下標進位元的問題。
//另外本例子中的寫文件語句效率比較低,?了降低演算法複雜度沒有優化。
//如果要提高寫文件的效率,可以使用緩衝區,分批寫入。
//*********************************************breath.cnpick.com***** void createpassword()
{
#define passwordmax 8//將生成密碼的最大長度 char a[]="0123456789abcdefghijklmnopqrstuvwxyz";//可能的字元
long ndictcount=sizeof(a);//獲得密碼詞典長度
char cpass[passwordmax 2];//將生成的密碼
long nminl=1,nmaxl=3;//本例中密碼長度從1-3
long array[passwordmax];//密碼詞典下標 assert(nminl<=nmaxl && nmaxl<=passwordmax);//容錯保證
long nlength=nminl;
register long j,i=0;
bool bnext;
cstdiofile file;
file.open("c:\\dict.txt",cfile::modecreate|cfile::modewrite);
while(nlength<=nmaxl)
{
for(i=0;i=0;j--)//密碼指標進位元
{
array[j] ;
if(array[j]!=ndictcount-1)break;
else
{
array[j]=0;
if(j==0)bnext=false;
}
} }
nlength ;
}
file.close();
}
發表人 - jackkcg 於 2002/10/01 02:32:47
------
********************************************************** 哈哈&兵燹 最會的2大絕招 這個不會與那個也不會 哈哈哈 粉好 Delphi K.Top的K.Top分兩個字解釋Top代表尖端的意思,希望本討論區能提供Delphi的尖端新知 K.表Knowlege 知識,就是本站的標語:Open our mind |
本站聲明 |
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。 2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。 3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇! |