python通过yield实现数组全排列的方法


Posted in Python onMarch 18, 2015

本文实例讲述了python通过yield实现数组全排列的方法。分享给大家供大家参考。具体分析如下:

从n个不同元素中任取m(m≤n)个元素,按照一定的顺序排列起来,叫做从n个不同元素中取出m个元素的一个排列。当m=n时所有的排列情况叫全排列。
这段代码用到了yield方法,全排列速度加倍

def perm(arr, pos = 0):
  if pos == len(arr):
    yield arr
  for i in range(pos, len(arr)):
    arr[pos], arr[i] = arr[i], arr[pos]
    for _ in perm(arr, pos + 1): yield _
    arr[pos], arr[i] = arr[i], arr[pos]
for i in perm([1,2,3,4]):
  print i

希望本文所述对大家的Python程序设计有所帮助。

Python 相关文章推荐
使用SAE部署Python运行环境的教程
May 05 Python
在Django的上下文中设置变量的方法
Jul 20 Python
Django中Model的使用方法教程
Mar 07 Python
python树莓派红外反射传感器
Jan 21 Python
用python3 返回鼠标位置的实现方法(带界面)
Jul 05 Python
wxPython实现整点报时
Nov 18 Python
python计算无向图节点度的实例代码
Nov 22 Python
pytorch masked_fill报错的解决
Feb 18 Python
python 计算概率密度、累计分布、逆函数的例子
Feb 25 Python
python GUI库图形界面开发之PyQt5下拉列表框控件QComboBox详细使用方法与实例
Feb 27 Python
详解Pycharm安装及Django安装配置指南
Sep 15 Python
python爬虫爬取图片的简单代码
Jan 18 Python
python以环状形式组合排列图片并输出的方法
Mar 17 #Python
python将ip地址转换成整数的方法
Mar 17 #Python
python实现模拟按键,自动翻页看u17漫画
Mar 17 #Python
python通过pil为png图片填充上背景颜色的方法
Mar 17 #Python
python按照多个字符对字符串进行分割的方法
Mar 17 #Python
python通过floor函数舍弃小数位的方法
Mar 17 #Python
python常规方法实现数组的全排列
Mar 17 #Python
You might like
PHP mkdir()定义和用法
2009/01/14 PHP
ThinkPHP 3.2 版本升级了哪些内容
2015/03/05 PHP
php以fastCGI的方式运行时文件系统权限问题及解决方法
2015/05/11 PHP
简单谈谈favicon
2015/06/10 PHP
PHP开发之归档格式phar文件概念与用法详解【创建,使用,解包还原提取】
2017/11/17 PHP
PHP信号处理机制的操作代码讲解
2019/04/19 PHP
jQuery使用手册之 事件处理
2007/03/24 Javascript
原生js做的手风琴效果的导航菜单
2013/11/08 Javascript
深入浅析JavaScript中数据共享和数据传递
2016/04/25 Javascript
浅谈Angular 中何时取消订阅
2017/11/22 Javascript
推荐10款扩展Web表单的JS插件
2017/12/25 Javascript
详解JS转换数值函数Number()、parseInt()、parseFloat()
2018/08/24 Javascript
vue.js input框之间赋值方法
2018/08/24 Javascript
Bootstrap fileinput 上传新文件移除时触发服务器同步删除的配置
2018/10/08 Javascript
vue自定义指令directive的使用方法
2019/04/07 Javascript
VUE前后端学习tab写法实例
2019/08/06 Javascript
解决vue scoped scss 无效的问题
2020/09/04 Javascript
[40:03]Liquid vs Optic 2018国际邀请赛淘汰赛BO3 第一场 8.21
2018/08/22 DOTA
详解Python字符串切片
2019/05/20 Python
关于pytorch中全连接神经网络搭建两种模式详解
2020/01/14 Python
python with (as)语句实例详解
2020/02/04 Python
django xadmin 管理器常用显示设置方式
2020/03/11 Python
Python列表去重复项的N种方法(实例代码)
2020/05/12 Python
Python爬虫scrapy框架Cookie池(微博Cookie池)的使用
2021/01/13 Python
VICHY薇姿英国官网:全球专业敏感肌护肤领先品牌
2017/07/04 全球购物
美国领先的奢侈美容零售商:Bluemercury
2017/07/26 全球购物
Maisons du Monde德国:法国家具和装饰的市场领导者
2019/07/26 全球购物
New Balance比利时官方网站:购买鞋子和服装
2021/01/15 全球购物
小学端午节活动方案
2014/03/13 职场文书
服务标语大全
2014/06/18 职场文书
2014年派出所工作总结
2014/11/21 职场文书
学校元旦晚会开场白
2014/12/14 职场文书
在校生证明
2015/06/17 职场文书
广告文案的撰写技巧(实用干货)
2019/08/23 职场文书
springboot如何初始化执行sql语句
2021/06/22 Java/Android
java实现自定义时钟并实现走时功能
2022/06/21 Java/Android