加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

Python全排列操作实例分析

发布时间:2020-12-16 21:05:04 所属栏目:Python 来源:网络整理
导读:本篇章节讲解Python全排列操作。供大家参考研究具体如下: step 1: 列表的全排列: 这个版本比较low # -*-coding:utf-8 -*-#!python3def permutation(li,index): for i in range(index,len(li)): if index == len(li)-1: print(li) return tmp = li

本篇章节讲解Python全排列操作。分享给大家供大家参考,具体如下:

step 1: 列表的全排列:

这个版本比较low

# -*-coding:utf-8 -*-
#!python3
def permutation(li,index):
  for i in range(index,len(li)):
    if index == len(li)-1:
      print(li)
      return
    tmp = li[index]
    li[index] = li[i]
    li[i] = tmp
    permutation(li,index+1)
    tmp = li[index]
    li[index] = li[i]
    li[i] = tmp

调用:

permutation([1,2,3,4],0)

运行结果:

[1,4]
[1,4,3]
[1,2]
[1,3]
[2,1,4]
[2,1]
[2,3]
[3,4]
[3,1]
[3,2]
[3,1]
[4,3]
[4,2]
[4,3]

step2: 字符串的全排列:

# -*-coding:utf-8 -*-
#!python3
def permutation(str):
  li = list(str)
  cnt = 0 #记录全排列的总数
  def permutation_list(index):
    if index == len(li) -1:
      nonlocal cnt
      cnt += 1
      print(li)
    for i in range(index,len(li)):
      li[index],li[i] = li[i],li[index]
      permutation_list(index+1)
      li[index],li[index]
  ret = permutation_list(0)
  print("共有%d中全排列" % cnt)
  return ret

备注:

在闭包中,内部函数依然维持了外部函数中自由变量的引用―单元。内部函数不能修改单元对象的值(但是可以引用)。若尝试修改,则解释器会认为它是局部变量。这类似于全局变量和局部变量的关系。如果在函数内部修改全局变量,必须加上global声明,但是对于自由变量,尚没有类似的机制。所以,只能使用列表。(python3中引入了关键字:nonlocal)

测试:

permutation('abcd')

运行结果:

['a','b','c','d']
['a','d','c']
['a','b']
['a','c']
['b','a','d']
['b','a']
['b','c']
['c','d']
['c','a']
['c','b']
['c','a']
['d','c']
['d','b']
['d','c']
共有24中全排列

step3 : 使用python标准库

import itertools
t = list(itertools.permutations([1,4]))
print(t)

运行结果:

[(1,4),(1,3),2),(2,1),(3,(4,1)]

可以指定排列的位数:

import itertools
t = itertools.permutations([1,3) #只排列3位
print(list(t))

运行结果:

[(1,2)]

更多关于Python相关内容感兴趣的读者可查看本站专题:《Python数学运算技巧总结》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》、《Python入门与进阶经典教程》及《Python文件与目录操作技巧汇总》

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

您可能感兴趣的文章:

  • python使用递归解决全排列数字示例
  • python常规方法实现数组的全排列
  • python标准算法实现数组全排列的方法
  • python不带重复的全排列代码
  • python回溯法实现数组全排列输出实例分析
  • python通过yield实现数组全排列的方法
  • python非递归全排列实现方法
  • Python基于回溯法子集树模板解决全排列问题示例
  • python3实现字符串的全排列的方法(无重复字符)

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读