分享
 
 
 

递归法提升密码穷举算法性能

王朝other·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

在Google中查询“密码穷举算法”,可以得到大约5千个的结果,提供了一个C的算法实例。本文不想再重复拷贝这些实例代码,如果需要的兄弟可以在Google上搜索获得。本人在研读这些代码后,觉得可以使用递归以提升该算法的性能。 惭愧的紧,本人对C代码就好像对上海话一样,能听懂一点,却说不溜。一句话,半调子。因此本文使用了VB.NET语言,希望大家可以理解。VB嘛,更好懂。

下面提供了两段代码,使用了相同的声明。

Friend Delegate Sub CallBack(ByVal Password As String) ' 密码输出回调

Private Const PStartLen As Integer = 1

Private Const PMaxLen As Integer = 6 ' 生成密码的最大长度

Private PDict() As Char = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz".ToCharArray ' 密码词典

第一段是C代码的一个VB.NET翻版:

' 翻版

Friend Sub MakePass_General(ByVal Cnn As CallBack)

Dim PDictLen As Long = Len(PDict) ' 获得密码词典长度

Dim CPass(PMaxLen - 1) As String ' 将生成的密码

Dim PLen As Integer

For PLen = PStartLen To PMaxLen ' 密码长度

Dim Array(PMaxLen - 1) As Integer ' 密码词典下标

Dim bNext As Boolean = True

While bNext

Dim i, j As Integer

For i = 0 To PLen - 1

CPass(i) = PDict(Array(i))

Next

Cnn.Invoke(String.Join("", CPass)) ' 密码输出

For j = PLen - 1 To 0 Step -1 ' 密码指针进位

Array(j) += 1

If Array(j) < PDictLen Then

Exit For

Else

Array(j) = 0

If (j = 0) Then bNext = False

End If

Next

End While

Next

End Sub

第二段代码,使用了递归法进行了优化:

' 递归法密码穷举算法

Friend Sub MakePass_Recursion(ByVal Cnn As CallBack)

Dim PLen As Integer

For PLen = PStartLen To PMaxLen ' 密码长度

Dim CPass(PLen - 1) As String ' 将生成的密码

MakePass_Recursion(Cnn, CPass)

Next

End Sub

Private Sub MakePass_Recursion(ByVal Cnn As CallBack, ByRef CPass() As String, Optional ByVal ID As Integer = 0)

Dim i As Integer

For i = 0 To PDict.Length - 1

CPass(ID) = PDict(i)

If ID = CPass.Length - 1 Then

Cnn.Invoke(String.Join("", CPass)) ' 密码输出

Else

MakePass_Recursion(Cnn, CPass, ID + 1)

End If

Next

End Sub

代码很简单,勿虚多言。对两段代码进行了测试,使用递归法优化后的密码穷举算法较常规的算法提高了大约1倍的速度。

班门弄斧,让高手们见笑了。请多指教。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有