国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術文章
文章詳情頁

淺談python輸出列表元素的所有排列形式

瀏覽:80日期:2022-08-05 18:16:55

例如:

[‘a’, ‘b’, ‘c’] 輸出 [‘a’, ‘b’, ‘c’] [‘a’, ‘c’, ‘b’] [‘b’, ‘a’, ‘c’] [‘b’, ‘c’, ‘a’] [‘c’, ‘a’, ‘b’] [‘c’, ‘b’, ‘a’]

方法一:利用遞歸的方式實現

def permutation(li): len_list = len(li) if len_list == 1: return li result = [] for i in range(len_list): res_list = li[:i] + li[i+1:] s = li[i] per_result = permutation(res_list) if len(per_result) == 1: result.append(li[i:i + 1] + per_result) else: result += [[s] + j for j in per_result] return result

方法二:利用python自帶的模塊

import itertoolsdef permutation(li): print(list(itertools.permutations(li)))

補充拓展:python實現四個數字的全排列

首先我們使用常規做法,循環交換完成。

lst = [1, 3, 5, 8]for i in range(0, len(lst)): lst[i], lst[0] = lst[0], lst[i] for j in range(1, len(lst)): lst[j], lst[1] = lst[1], lst[j] for h in range(2, len(lst)): print(lst) lst[j], lst[1] = lst[1], lst[j] lst[i], lst[0] = lst[0], lst[i]

如果列表較長,元素較多,以上常規方法實現起來就比較吃力了,以下我們采用遞歸方式實現。

def permutations(position): if position == len(lst) - 1: print(lst) else: for index in range(position, len(lst)): lst[index], lst[position] = lst[position], lst[index] permutations(position+1) lst[index], lst[position] = lst[position], lst[index]permutations(0)

以上這篇淺談python輸出列表元素的所有排列形式就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 钟山县| 小金县| 亚东县| 玛曲县| 巴林左旗| 多伦县| 娄烦县| 合江县| 宜黄县| 浑源县| 新乐市| 香格里拉县| 武隆县| 玉门市| 电白县| 河东区| 禄丰县| 德昌县| 石棉县| 江安县| 桂东县| 高邑县| 贵定县| 永康市| 普兰店市| 清镇市| 西昌市| 崇礼县| 土默特右旗| 霍林郭勒市| 富宁县| 天气| 克东县| 康平县| 行唐县| 泸西县| 铜梁县| 丽水市| 来安县| 霍林郭勒市| 忻州市|