python语言的全排列怎么提速?
python从n个不同元素中任取m(m≤n)个元素,按照一定的顺序排列起来,叫做从n个不同元素中取出m个元素的一个排列。当m=n时所有的排列情况叫全排列。显然全排列很费时,这里用到了yield方法,全排列速度加倍
什么是yield()方法?
首先,如果你还没有对yield有个初步分认识,那么你先把yield看做“return”,这个是直观的,它首先是个return,普通的return是什么意思,就是在程序中返回某个值,返回之后程序就不再往下运行了。看做return之后再把它看做一个是生成器(generator)的一部分(带yield的函数才是真正的迭代器),好了,如果你对这些不明白的话,那先把yield看做return,然后直接看下面的程序,你就会明白yield的全部意思了:
deffoo():
print("starting...")
whileTrue:
res=yield4
print("res:",res)
g=foo()
print(next(g))
print("*"*20)
print(next(g))
代码的输出:
starting...
4
********************
res:None
使用yield()方法的全排列:
defperm(arr,pos=0):
ifpos==len(arr):
yieldarr
foriinrange(pos,len(arr)):
arr[pos],arr[i]=arr[i],arr[pos]
for_inperm(arr,pos+1):yield_
arr[pos],arr[i]=arr[i],arr[pos]
foriinperm([1,2,3,4]):
printi
以上内容为大家介绍了Python培训之语言的全排列怎么提速?,希望对大家有所帮助,如果想要了解更多Python相关知识,请关注IT培训机构:千锋教育。
相关推荐HOT
更多>>python strftime和strptime的不同分析
pythonstrftime和strptime的不同分析本篇以strftime和strptime的定义为基础,再带来相关的使用实例,帮助大家找出两种函数在转换时的不同点,下...详情>>
2023-11-12 23:16:12python继承类中如何重写?
python继承类中如何重写?本文教程操作环境:windows7系统、Python3.9.1,DELLG3电脑。1、重写的类别(1)重写和父类的方法名称一样。但是在子类里...详情>>
2023-11-12 22:30:38python中series如何转为list?
python中series如何转为list?Series是python中Pandas包的一个数据结构,与Python基本的数据结构List也很相近,但是作为原生的python数据结构类...详情>>
2023-11-12 21:47:05python绝对引用和相对引用的差异
python绝对引用和相对引用的差异本文教程操作环境:windows7系统、Python3.9.1,DELLG3电脑。1、差异绝对引用是明确指定最高级文件(夹),文件之...详情>>
2023-11-12 13:27:23热门推荐
python中如何编写函数并调用?
沸python strftime和strptime的不同分析
热python继承类中如何重写?
热python中series如何转为list?
新python中list与array有什么区别?
pandas中Series常见属性有哪些?
time.localtime在python中的使用
python中如何使用scipy.stats产生随机数?
python描述器的访问顺序
Python中Operator计算函数
Python中使用K-means算法
python合并表格的两种方法
python绝对和相对导入的介绍
pythonOpenCV调节亮度