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

首頁 > 編程 > Python > 正文

python遞歸全排列實現方法

2020-02-15 22:47:02
字體:
來源:轉載
供稿:網友

本文實例為大家分享了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>>> 

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 遂平县| 罗源县| 乾安县| 河北区| 叙永县| 扎鲁特旗| 年辖:市辖区| 绥中县| 荔浦县| 宁远县| 隆尧县| 木兰县| 陆河县| 保靖县| 临朐县| 达州市| 阳谷县| 富阳市| 七台河市| 榆社县| 永福县| 同江市| 贺兰县| 济宁市| 贵州省| 菏泽市| 荆门市| 黔西县| 沙坪坝区| 大厂| 黑龙江省| 大庆市| 施甸县| 雅江县| 蒙山县| 应用必备| 营山县| 镇赉县| 南乐县| 乐昌市| 上林县|