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

首頁 > 編程 > Python > 正文

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

2020-01-04 16:16:13
字體:
供稿:網(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__":  # 構(gòu)造二維數(shù)組  datagroup = [['aa1', ], ['bb1', 'bb2'], ['cc1', 'cc2', 'cc3']]  # 創(chuàng)建cartesian對象  cartesian = Cartesian(datagroup)  cartesian.assemble()

輸出結(jié)果:

Python2.7,笛卡爾積,算法,數(shù)組,排列組合

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

希望本文所述對大家Python程序設計有所幫助。


注:相關(guān)教程知識閱讀請移步到python教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 桃源县| 侯马市| 巴楚县| 三江| 蓝山县| 无为县| 招远市| 济宁市| 敦化市| 和田县| 乐东| 铅山县| 株洲市| 利川市| 房产| 邵东县| 望江县| 靖宇县| 万荣县| 思南县| 东安县| 中宁县| 财经| 莆田市| 洛川县| 富锦市| 襄樊市| 宁明县| 和硕县| 高陵县| 称多县| 四子王旗| 安图县| 抚宁县| 兰坪| 会理县| 黔南| 安溪县| 电白县| 丹巴县| 县级市|