排列組合(破解密碼)
關注公衆號“輕鬆學編程”瞭解更多。
1.排列
itertools.permutations(iterable,n)
參數一:要排列的序列,
參數二:要選取的個數
返回的是一個迭代對象,迭代器中的每一個元素都是一個元組
import itertools
# 概念:從n個不同元素中取出m(m≤n)個元素,按照一定的順序排成一列,
# 叫做從n個元素中取出m個元素的一個排列(Arrangement)。
# 特別地,當m=n時,這個排列被稱作全排列(Permutation)
'''
1 2 3 4
假設從中取出3個數字
123
132
213
231
321
312
'''
#需求:從[1,2,3,4]4個數中隨機取出3個數進行排列
mylist = list(itertools.permutations([1,2,3,4], 3))
print(mylist)
print(len(mylist))
'''
規律總結:
4 - 3 24
4 - 2 12
4 - 1 4
排列的可能性次數:n! / (n-m)!
'''
2.組合
itertools.combinations(iterable,n)
參數一:可迭代對象
參數二:要選取的個數
返回值:返回一二迭代器,迭代器中的每一個元素都是一個元組
import itertools
# 概念:從m個不同的元素中,任取n(n≤m)個元素爲一組,
# 叫作從m個不同元素中取出n個元素的進行組合
'''
1 2 3 4 5 中選4個數的組合方式有幾種?
'''
mylist = list(itertools.combinations([1,2,3,4,5], 4))
print(mylist)
print(len(mylist))
'''
規律總結:
m n
5 - 5 1
5 - 4 5
5 - 3 10
5 - 2 10
5!
120/120(m-n)!
120/24(m-n)!
120/6(m-n)!
m!/(n!x(m-n)!)
'''
3.排列組合
itertools.product(iterable,repeat=1)
參數一:可迭代對象,參數二:重複的次數,默認爲1
import itertools
'''
_ _ _ _ _
'''
mylist = list(itertools.product("0123456789QWERTYUIOPASDFGHJKLZXCVBNMqwertyuiopasdfghjklzxcvbnm", repeat=6))
#可以嘗試10,有可能電腦會卡住
#多線程也不行,電腦內存不夠,咋處理都白搭
#print(mylist)
print(len(mylist))
擴展:現在但凡涉及到密碼,一般都會進行加密處理,常用的加密方式有MD5,RSA,DES等
4.瘋狂破解密碼
傷敵一千自損一萬的破解方式
import time
import itertools
#mylist = list(itertools.product("0123456789", repeat=10))
passwd = ("".join(x) for x in itertools.product("0123456789QWERTYUIOPASDFGHJKLZXCVBNMqwertyuiopasdfghjklzxcvbnm", repeat=6))
#print(mylist)
#print(len(mylist))
while True:
#先直接實現,然後再添加異常
try:
str = next(passwd)
time.sleep(0.5)
print(str)
except StopIteration as e:
break
後記
【後記】爲了讓大家能夠輕鬆學編程,我創建了一個公衆號【輕鬆學編程】,裏面有讓你快速學會編程的文章,當然也有一些乾貨提高你的編程水平,也有一些編程項目適合做一些課程設計等課題。
也可加我微信【1257309054】,拉你進羣,大家一起交流學習。
如果文章對您有幫助,請我喝杯咖啡吧!
公衆號
關注我,我們一起成長~~