Python2.7基于笛卡爾積算法實(shí)現(xiàn)N個(gè)數(shù)組的排列組合運(yùn)算示例
本文實(shí)例講述了Python2.7基于笛卡爾積算法實(shí)現(xiàn)N個(gè)數(shù)組的排列組合運(yùn)算。分享給大家供大家參考,具體如下:
說(shuō)明:本人前段時(shí)間遇到的求n個(gè)數(shù)組的所有排列組合的問(wèn)題,發(fā)現(xiàn)笛卡爾積算法可以解決,但是網(wǎng)上搜索的只有Java版本的實(shí)現(xiàn),于是自己試著用python實(shí)現(xiàn),由于新手代碼不太規(guī)范。
代碼:本人封裝了一個(gè)類Cartesian(笛卡爾),其中封裝了變量和方法:
1.變量
datagroup : 表示n個(gè)list(python 中的list與其他編程中的數(shù)組定義類似)的集合,即一個(gè)二維數(shù)組
counterIndex:datagroup反向下標(biāo)值
counter : 用來(lái)記錄當(dāng)前datagroup中每一個(gè)數(shù)組輸出的下標(biāo),初始全為0,因?yàn)閺牡谝粋€(gè)開始輸出
2.方法
countlength : 計(jì)算數(shù)組長(zhǎng)度,即計(jì)算n的具體值
handle :處理datagoroup二維數(shù)組中每一個(gè)一維數(shù)組輸出的下標(biāo)值
assemble : 對(duì)datagoroup中的n個(gè)一維數(shù)組中的每一元素進(jìn)行排列組合輸出
# -*- coding:utf-8 -*-
# python 實(shí)現(xiàn)N個(gè)數(shù)組的排列組合(笛卡爾積算法)
class Cartesian():
# 初始化
def __init__(self, datagroup):
self.datagroup = datagroup
# 二維數(shù)組從后往前下標(biāo)值
self.counterIndex = len(datagroup)-1
# 每次輸出數(shù)組數(shù)值的下標(biāo)值數(shù)組(初始化為0)
self.counter = [0 for i in range(0, len(self.datagroup))]
# 計(jì)算數(shù)組長(zhǎng)度
def countlength(self):
i = 0
length = 1
while(i < len(self.datagroup)):
length *= len(self.datagroup[i])
i += 1
return length
# 遞歸處理輸出下標(biāo)
def handle(self):
# 定位輸出下標(biāo)數(shù)組開始從最后一位遞增
self.counter[self.counterIndex]+=1
# 判斷定位數(shù)組最后一位是否超過(guò)長(zhǎng)度,超過(guò)長(zhǎng)度,第一次最后一位已遍歷結(jié)束
if self.counter[self.counterIndex] >= len(self.datagroup[self.counterIndex]):
# 重置末位下標(biāo)
self.counter[self.counterIndex] = 0
# 標(biāo)記counter中前一位
self.counterIndex -= 1
# 當(dāng)標(biāo)記位大于等于0,遞歸調(diào)用
if self.counterIndex >= 0:
self.handle()
# 重置標(biāo)記
self.counterIndex = len(self.datagroup)-1
# 排列組合輸出
def assemble(self):
length = self.countlength()
i = 0
while(i < length):
attrlist = []
j = 0
while(j<len(self.datagroup)):
attrlist.append(self.datagroup[j][self.counter[j]])
j += 1
print attrlist
self.handle()
i += 1
測(cè)試:
注:測(cè)試代碼中我只選取了長(zhǎng)度為3的二維數(shù)組
if __name__ == "__main__": # 構(gòu)造二維數(shù)組 datagroup = [['aa1', ], ['bb1', 'bb2'], ['cc1', 'cc2', 'cc3']] # 創(chuàng)建cartesian對(duì)象 cartesian = Cartesian(datagroup) cartesian.assemble()
輸出結(jié)果:

備注:此算法實(shí)現(xiàn)用python2.7版本
更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python加密解密算法與技巧總結(jié)》、《Python編碼操作技巧總結(jié)》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》及《Python入門與進(jìn)階經(jīng)典教程》
希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。
- python 排列組合之itertools
- Python實(shí)現(xiàn)的排列組合計(jì)算操作示例
- Python實(shí)現(xiàn)的簡(jiǎn)單排列組合算法示例
- Python編程之黑板上排列組合,你舍得解開嗎
- Python列表list排列組合操作示例
- Python使用itertools模塊實(shí)現(xiàn)排列組合功能示例
- Python使用combinations實(shí)現(xiàn)排列組合的方法
- 忘記ftp密碼的解決方法示例
- Python腳本暴力破解柵欄密碼
- Python實(shí)現(xiàn)在線暴力破解郵箱賬號(hào)密碼功能示例【測(cè)試可用】
- Python利用字典破解WIFI密碼的方法
- Python實(shí)現(xiàn)的排列組合、破解密碼算法示例
相關(guān)文章
Python+SeaTable實(shí)現(xiàn)計(jì)算兩個(gè)日期間的工作日天數(shù)
在實(shí)際的項(xiàng)目管理、任務(wù)管理、工作計(jì)劃等場(chǎng)景中,某些時(shí)間段會(huì)涉及雙休日、法定節(jié)假日,甚至還有公司自定義的工作時(shí)間安排,所以就需要計(jì)算出兩個(gè)日期間的實(shí)際工作日天數(shù)。本文用Python+SeaTable實(shí)現(xiàn)這一需求,需要的可以參考一下2022-07-07
Python通過(guò)DOM和SAX方式解析XML的應(yīng)用實(shí)例分享
這篇文章主要介紹了Python通過(guò)DOM和SAX方式解析XML的應(yīng)用實(shí)例分享,針對(duì)這兩種解析方式Python都有相關(guān)的模塊可供使用,需要的朋友可以參考下2015-11-11
python中is與雙等于號(hào)“==”的區(qū)別示例詳解
Python中有很多運(yùn)算符,下面這篇文章主要給大家介紹了關(guān)于python中is與雙等于號(hào)“==”區(qū)別的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2017-11-11
關(guān)于pandas-profiling的降級(jí)之旅
這篇文章主要介紹了關(guān)于pandas-profiling的降級(jí)之旅,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-11-11
關(guān)于Python中進(jìn)度條的六個(gè)實(shí)用技巧分享
在項(xiàng)目開發(fā)過(guò)程中加載、啟動(dòng)、下載項(xiàng)目難免會(huì)用到進(jìn)度條,下面這篇文章主要給大家介紹了關(guān)于Python中進(jìn)度條的六個(gè)實(shí)用技巧,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-04-04
Python使用Pandas庫(kù)常見(jiàn)操作詳解
這篇文章主要介紹了Python使用Pandas庫(kù)常見(jiàn)操作,結(jié)合實(shí)例形式詳細(xì)分析了Python Pandas模塊的功能、原理、數(shù)據(jù)對(duì)象創(chuàng)建、查看、選擇等相關(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下2020-01-01
Django配合python進(jìn)行requests請(qǐng)求的問(wèn)題及解決方法
Python作為目前比較流行的編程語(yǔ)言,他內(nèi)置的Django框架就是一個(gè)很好的網(wǎng)絡(luò)框架,可以被用來(lái)搭建后端,和前端進(jìn)行交互,那么我們現(xiàn)在來(lái)學(xué)習(xí)一下,如何用Python本地進(jìn)行requests請(qǐng)求,并通過(guò)請(qǐng)求讓Django幫我們解決一些問(wèn)題2022-06-06
關(guān)于Python中幾種隊(duì)列Queue用法區(qū)別
這篇文章主要介紹了關(guān)于Python中幾種隊(duì)列Queue用法區(qū)別,queue隊(duì)列中的put()或者get()方法中都提供了timeout參數(shù),利用這個(gè)參數(shù)可以有效解決上述消除不能消費(fèi)和線程一直阻塞問(wèn)題,需要的朋友可以參考下2023-05-05

