国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Python2.7基于笛卡爾積算法實現(xiàn)N個數(shù)組的排列組合運算示例

2020-02-16 10:50:07
字體:
供稿:網(wǎng)友

本文實例講述了Python2.7基于笛卡爾積算法實現(xiàn)N個數(shù)組的排列組合運算。分享給大家供大家參考,具體如下:

說明:本人前段時間遇到的求n個數(shù)組的所有排列組合的問題,發(fā)現(xiàn)笛卡爾積算法可以解決,但是網(wǎng)上搜索的只有Java版本的實現(xiàn),于是自己試著用python實現(xiàn),由于新手代碼不太規(guī)范。

代碼:本人封裝了一個類Cartesian(笛卡爾),其中封裝了變量和方法:

1.變量

datagroup : 表示n個list(python 中的list與其他編程中的數(shù)組定義類似)的集合,即一個二維數(shù)組
counterIndex:datagroup反向下標值
counter : 用來記錄當前datagroup中每一個數(shù)組輸出的下標,初始全為0,因為從第一個開始輸出

2.方法

countlength : 計算數(shù)組長度,即計算n的具體值
handle :處理datagoroup二維數(shù)組中每一個一維數(shù)組輸出的下標值
assemble : 對datagoroup中的n個一維數(shù)組中的每一元素進行排列組合輸出

# -*- coding:utf-8 -*-# python 實現(xiàn)N個數(shù)組的排列組合(笛卡爾積算法)class Cartesian():  # 初始化  def __init__(self, datagroup):    self.datagroup = datagroup    # 二維數(shù)組從后往前下標值    self.counterIndex = len(datagroup)-1    # 每次輸出數(shù)組數(shù)值的下標值數(shù)組(初始化為0)    self.counter = [0 for i in range(0, len(self.datagroup))]  # 計算數(shù)組長度  def countlength(self):    i = 0    length = 1    while(i < len(self.datagroup)):      length *= len(self.datagroup[i])      i += 1    return length  # 遞歸處理輸出下標  def handle(self):    # 定位輸出下標數(shù)組開始從最后一位遞增    self.counter[self.counterIndex]+=1    # 判斷定位數(shù)組最后一位是否超過長度,超過長度,第一次最后一位已遍歷結(jié)束    if self.counter[self.counterIndex] >= len(self.datagroup[self.counterIndex]):      # 重置末位下標      self.counter[self.counterIndex] = 0      # 標記counter中前一位      self.counterIndex -= 1      # 當標記位大于等于0,遞歸調(diào)用      if self.counterIndex >= 0:        self.handle()      # 重置標記      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

測試:

注:測試代碼中我只選取了長度為3的二維數(shù)組

if __name__ == "__main__":  # 構造二維數(shù)組  datagroup = [['aa1', ], ['bb1', 'bb2'], ['cc1', 'cc2', 'cc3']]  # 創(chuàng)建cartesian對象  cartesian = Cartesian(datagroup)  cartesian.assemble()

輸出結(jié)果:

備注:此算法實現(xiàn)用python2.7版本

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 凌源市| 通化县| 栾川县| 景谷| 堆龙德庆县| 中方县| 浦北县| 健康| 道孚县| 丰县| 进贤县| 鄢陵县| 惠州市| 鹤庆县| 沙湾县| 乐业县| 正阳县| 厦门市| 定襄县| 都匀市| 凤阳县| 城步| 邹城市| 女性| 天祝| 五台县| 金溪县| 罗源县| 德昌县| 本溪| 彭水| 阜新市| 灯塔市| 南皮县| 贵阳市| 南平市| 灵宝市| 孝义市| 乐亭县| 桓仁| 安化县|