簡單介紹python輸出列表元素的所有排列形式
今天小編就為大家分享一篇淺談python輸出列表元素的所有排列形式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧 |
例如:
[‘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 itertools def 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輸出列表元素的所有排列形式就是小編分享給大家的全部內容了,希望能給大家一個參考。
原文地址:
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/31559985/viewspace-2679713/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- <svg>元素簡單介紹SVG
- Python簡單介紹Python
- 簡單介紹四種Python 列表反轉顯示的方法Python
- 簡單介紹python在CMD介面讀取excel所有資料PythonExcel
- Html 5.2 的簡單介紹及新增元素 <dialog></dialog>HTML
- 簡單介紹SpringMVC RESTFul實現列表功能SpringMVCREST
- 簡單介紹python process模組Python
- 簡單介紹python的垃圾回收機制Python
- 所有輸入(程式碼形式)
- JavaScript 輸出介紹JavaScript
- 簡單介紹Golang切片刪除指定元素的三種方法Golang
- python如何以表格形式列印輸出Python
- Webpack 的簡單介紹Web
- AOP的簡單介紹
- 簡單介紹5個python的實用技巧Python
- 簡單介紹python中的mock介面開發PythonMock
- 簡單介紹python的input,print,eval函式Python函式
- form表單的簡單介紹ORM
- Flownet 介紹 及光流的簡單介紹
- 開發一個簡單的工具,匯出github倉庫所有issue列表Github
- python列表追加元素出錯的解決Python
- vue匯出excel(簡單方法完整介紹)VueExcel
- 簡單介紹python中的單向連結串列實現Python
- 簡單介紹Python中的配對函式zip()Python函式
- 簡單介紹python虛擬環境 virtualenv的使用Python
- Python - pydantic 入門介紹與 Models 的簡單使用Python
- 簡單介紹Python 處理錯誤的原則Python
- RPC簡單介紹RPC
- KVM簡單介紹
- RMI簡單介紹
- HTML簡單介紹HTML
- HTML 簡單介紹HTML
- JavaScript 簡單介紹JavaScript
- CSS 簡單介紹CSS
- ajax簡單介紹
- SVG簡單介紹SVG
- Clickjacking簡單介紹
- 【Pandas】簡單介紹