python常规方法实现数组的全排列
本文实例讲述了常规方法实现python数组的全排列操作。分享给大家供大家参考。具体分析如下:
全排列解释:从n个不同元素中任取m(m≤n)个元素,按照一定的顺序排列起来,叫做从n个不同元素中取出m个元素的一个排列。当m=n时所有的排列情况叫全排列。
defperm(l): if(len(l)<=1): return[l] r=[] foriinrange(len(l)): s=l[:i]+l[i+1:] p=perm(s) forxinp: r.append(l[i:i+1]+x) returnr
调用方法:
if__name__=='__main__':
"""defaultparamislist(1,2,3,4,5)"""
l=[];
if(len(sys.argv)<=1):
"""input=['%d'%(i)foriinxrange(1,6)]"""
l=list((1,2,3,4,5))
else:#inputparamlookslike"2,3,4,5,6",nolegalcheckshere.
input=str(sys.argv[1])
l=input.split(",")
foriinxrange(len(l)):
l[i]=int(l[i])
printperm(l)
希望本文所述对大家的Python程序设计有所帮助。