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

首頁 > 編程 > Python > 正文

python遞歸全排列實現方法

2020-01-04 14:41:37
字體:
來源:轉載
供稿:網友

本文實例為大家分享了python遞歸全排列的實現方法,供大家參考,具體內容如下

排列:從n個元素中任取m個元素,并按照一定的順序進行排列,稱為排列;
全排列:當n==m時,稱為全排列;

比如:集合{ 1,2,3}的全排列為:
{ 1 2 3} 
{ 1 3 2 }
{ 2 1 3 }
{ 2 3 1 }
{ 3 2 1 }
{ 3 1 2 }

遞歸思想:

取出數組中第一個元素放到最后,即a[1]與a[n]交換,然后遞歸求a[n-1]的全排列

1)如果數組只有一個元素n=1,a={1} 則全排列就是{1}
2)如果數組有兩個元素n=2,a={1,2} 則全排列是:
{2,1}--a[1]與a[2]交換。交換后求a[2-1]={2}的全排列,歸結到1)
{1,2}--a[2]與a[2]交換。交換后求a[2-1]={1}的全排列,歸結到1)
3)如果數組有三個元素n=3,a={1,2,3} 則全排列是
{{2,3},1}--a[1]與a[3]交換。后求a[3-1]={2,3}的全排列,歸結到2)
{{1,3},2)--a[2]與a[3]交換。后求a[3-1]={1,3}的全排列,歸結到2)
{{1,2},3)--a[3]與a[3]交換。后求a[3-1]={1,2}的全排列,歸結到2)
...

依此類推。

利用python實現全排列的具體代碼perm.py如下:

COUNT=0def perm(n,begin,end):  global COUNT  if begin>=end:    print n    COUNT +=1  else:    i=begin    for num in range(begin,end):      n[num],n[i]=n[i],n[num]      perm(n,begin+1,end)      n[num],n[i]=n[i],n[num] n=[1,2,3,4]perm(n,0,len(n))print COUNT

最后輸出的結果如下:

======================== RESTART: D:/Python27/perm.py ========================[1, 2, 3, 4][1, 2, 4, 3][1, 3, 2, 4][1, 3, 4, 2][1, 4, 3, 2][1, 4, 2, 3][2, 1, 3, 4][2, 1, 4, 3][2, 3, 1, 4][2, 3, 4, 1][2, 4, 3, 1][2, 4, 1, 3][3, 2, 1, 4][3, 2, 4, 1][3, 1, 2, 4][3, 1, 4, 2][3, 4, 1, 2][3, 4, 2, 1][4, 2, 3, 1][4, 2, 1, 3][4, 3, 2, 1][4, 3, 1, 2][4, 1, 3, 2][4, 1, 2, 3]24>>> 

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


注:相關教程知識閱讀請移步到python教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 玛纳斯县| 天祝| 安龙县| 文安县| 茂名市| 孟州市| 瑞安市| 中西区| 洛隆县| 西宁市| 大同县| 开原市| 鄂托克旗| 竹山县| 龙泉市| 花莲县| 新宁县| 怀安县| 常州市| 增城市| 饶平县| 山阳县| 上饶县| 惠州市| 汤原县| 邹城市| 思南县| 岑溪市| 新乡县| 比如县| 惠州市| 正定县| 靖西县| 民和| 舒兰市| 湛江市| 福建省| 鞍山市| 石台县| 冀州市| 通州区|