我的编程空间,编程开发者的网络收藏夹
学习永远不晚

python排列组合

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

python排列组合

1.Python的排列函数permutations()

itertools.permutations(iterable,r=None)

功能:连续返回由iterable序列中的元素生成的长度为r的排列
如果r未指定或为None,r默认设置为iterable的长度,即生成包含所有元素的全排列
简单应用示例如下:
代码清单1-1:

from itertools import *s=['a','b','c']for element in permutations(s,2):    a=element[0]+element[1]    # 或者这样写:    # a=''.join(element)  #join表示组合    print(a,end=' ')

输出:
ab ac ba bc ca cb

问:permutations()按什么顺序输出序列?
答:按元素的位置顺序输出元素的排列,也就是说,输出排列的顺序是位置的字典序。
例如s=[‘b’,‘a’,‘c’],执行permutations(s),输出“bac bca abc acb cba cab”,并不是按字符的字典序输出排列,而是按位置顺序输出。

如果有相同的元素,不同位置的元素被认为不同。例如s=[‘a’,‘a’,‘c’],执行permutations(s),输出“aac aca aac aca caa caa ”
代码清单1-2:

from itertools import *s=['a','a','c']for element in permutations(s):    a=''.join(element)    print(a,end=' ')

join方法只适用于字符型,数字可以采用for遍历的方法实现组合

代码清单1-3:

from itertools import *s=[1,3,2]for element in permutations(s):    for j in element:        print(j,end='')    print(' ',end='')

输出:
132 123 312 321 213 231

问:如何输出看起来正常的“123 132 213 231 312 321”?
答:先把s=[‘1’,‘3’,‘2’]用sort()排序之后再执行permutations()

代码清单1-4:

from itertools import *s=[1,3,2]s.sort()for i in permutations(s):    print(i,end='')

输出:
(1, 2, 3)(1, 3, 2)(2, 1, 3)(2, 3, 1)(3, 1, 2)(3, 2, 1)

2.Python的组合函数combinations()

permutations()输出的是排列,元素的排列是分先后的,但有时只需要输出组合,不用分先后,此时可以使用combinations()函数
代码清单2-1:

from itertools import *s=['1','3','2']for element in combinations(s,2):    a=''.join(element)    print(a,end=' ')

输出:
13 12 32

3种组合,6种排列

同样,如果序列s中有相等的元素,不同位置的相等元素被认为不同。

代码清单2-2:

from itertools import *s=['1','1','3','2']for element in combinations(s,2):    a=''.join(element)    print(a,end=' ')

输出:
11 13 12 13 12 32

会发现重复打印“12”和“13”,想要解决问题可以用集合进行去重

代码清单2-3:

from itertools import *s= {'1', '1', '3', '2'}for element in combinations(s,2):    a=''.join(element)    print(a,end=' ')

输出:
12 13 23

但如果用集合表示,输出顺序是随机的,多次执行代码1-7,会发现每次输出的顺序不同

如果要去重且输出按字典序:先用set()去重,再排序,最后组合
代码清单2-4:

from itertools import *s= {'1', '1', '3', '2'}t=list(set(s))t.sort()           #sort排序只对listfor element in combinations(t,2):    a=''.join(element)    print(a,end=' ')

from itertools import *s= {'1', '1', '3', '2'}t=sorted(set(s))       #sorted排序不需要转换为list for element in combinations(t,2):    a=''.join(element)    print(a,end=' ')

输出:
12 13 23

3.手写排列和组合代码

在某些场景下,Python提供的排列函数并不能用,需要手写代码实现排列组合。
下面是几种简单的手写方法:

手写排列代码:暴力法

代码清单3-1:

s=[1,2,3,4]for i in range(4):    #循环三次,选三个数    for j in range(4):        if j!=i:           #保证每个循环的数不同            for k in range(4):                if k!=i and k!=j:                    print("%d%d%d"%(s[i],s[j],s[k]),end=',')

输出:
123,124,132,134,142,143,213,214,231,234,241,243,312,314,321,324,341,342,412,413,421,423,431,432,

简单且效果好,但非常笨拙

手写组合代码:暴力法

代码清单3-2:

s=[1,2,3,4]for i in range(4):        #循环三次,选三个数    for j in range(i+1,4):            for k in range(j+1,4):      #让第二个数比第一个大,第三个数比第二个大                    print("%d%d%d"%(s[i],s[j],s[k]),end=',')

输出:
123,124,134,234,

排列数需要分先后,组合数不分先后,直接去掉if即可

手写组合代码:二进制法

一个包含n个元素的集合有2**n个子集,可以对应到二进制的概念,某一个集合中“有”或者“没有”这个元素,可以对应“1”或“0”
并且子集中的元素是不分先后的,这正符合组合的要求
下面的代码通过处理每个二进制数中的1,打印出 所有 的子集
代码清单3-3:

a=[1,2,3,4,5,6]n=3          #打印前n个元素a[0]~a[n-1]的所有子集for i in range(1<<n):     #1左位移3,相当于2**3    #i是选取000~111的8个数    print('{',end='')    #打印一个子集,即打印i的二进制数中的所有的1    for j in range(n):    #检查n次        if i & (1<<j):    #从i的最低位开始,逐个检查每一位,如果是1,打印            print(a[j],end=',')    print('}',end=';')

输出:
{};{1,};{2,};{1,2,};{3,};{1,3,};{2,3,};{1,2,3,};

那么如何输出n个数中任意m个数的组合?
根据上面子集生成的二进制方法,一个子集对应一个二进制数;一个有m个元素的子集,对应的二进制数中有m个1
问题转化为:查找1的个数为m个的二进制数,这些二进制数对应了需要打印的子集

方法:可以直接定位二进制数中1的位置,跳过中间的0
用到一个神奇操作:k=k&(k-1),功能是消除k的二进制数的最后一个1,连续进行这个操作,每次消除一个1,直到全部消除,操作次数就是1的个数
例如1011只需3次操作:
在这里插入图片描述
步骤:
用k=k&(k-1)清除k的最后一个1;
num++ 用num统计1的个数
继续上述操作,直到k=0

代码清单3-4:

a=[1,2,3,4,5,6,7]def print_set(n,m):       #在n个数中取m个数的组合    for i in range(2**n):     #2**n可以写成1<        num,k = 0,i           #num统计i中1的个数;k用来处理i        while(k>0):           #循环处理            k=k&(k-1)         #清除k中最后一个1            num +=1           #统计1的个数        if num == m:          #二进制数中的1有m个,符合条件            for j in range(n):                if (i&(2**j)):print(a[j],end=' ')            print("; ",end='')n,m=4,3           #a的前4个数中选3个组合print_set(n,m)

输出:
1 2 3 ; 1 2 4 ; 1 3 4 ; 2 3 4 ;

来源地址:https://blog.csdn.net/m0_75106254/article/details/128952114

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

python排列组合

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

python list的排列组合

排列例如: 输入为[‘1’,’2’,’3’]和3输出为[‘111’,’112’,’113’,’121’,’122’,’123’,’131’,’132’,’133’,’211’,’212’,’213’,’221’,’222’,’223’,’2
2023-01-31

python 排列组合算法

def c(n,m,out):if(m==0):   return 1x=nwhile x>=m:   out.append(x)   if(c(x-1,m-1,out)):    print out   out.pop()   x-=1r
2023-01-31

用python实现排列组合

比如我们要实现1,2,3的排列组合,我们可以很容易写出来,如下表:  1个元素2个元素3个元素不考虑顺序1231,2,312,13,23123考虑顺序1231,2,3,12,21,13,31,23,32123,132,213,231,312
2023-01-31

基于python快速实现排列组合算法

1.python语言简单、方便,其内部可以快速实现排列组合算法,下面做简单介绍、2.一个列表数据任意组合2.1主要是利用自带的库#_*_ coding:utf-8 _*_#__author__='dragon'import itertool
2023-01-31

字符串排列组合问题

给你一个字符串,比如‘abc’,请打印出该字符串的所有排列组合:以‘abc’为例,输出的结果应该是:'abc', 'acb', 'bac', 'bca', 'cab', 'cba'请用python代码编码实现: def fun1(s='')
2023-01-30

java如何实现排列组合算法

这篇文章主要介绍java如何实现排列组合算法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!java排列组合算法[@more@]import java.util.ArrayList;import java.util.L
2023-06-03

Python编程之黑板上排列组合,你舍得解开吗

考虑这样一个问题,给定一个矩阵(多维数组,numpy.ndarray()),如何shuffle这个矩阵(也就是对其行进行全排列),如何随机地选择其中的k行,这叫组合,实现一种某一维度空间的切片。例如五列中选三列(全部三列的排列数),便从原有
2022-06-04

iOS中排列组合算法的使用小结

前言 最近在项目中用到了排列组合计算,虽然比较简单,但是整个学习过程还是要记录下来的,以便以后可以吸取经验。一般来说,排列组合就等于搜索。 注意点:1.去重复:规定子集顺序必须升序;2.候选数组的结果处理。必须深拷贝,否则最后的结果集里全是
2022-05-26

c语言排列组合算法怎么实现

C语言排列组合算法可以通过递归实现。下面是一个示例代码:#include void combination(int arr[], int data[], int start, int end, int index, in
c语言排列组合算法怎么实现
2024-02-29

Python 列表&元组&字典&集合

列表(list)有序性,可存储任意类型的值通过偏移存取,支持索引来读取元素,第一个索引为0 ,倒数第一个索引为-1可变性 ,支持切片、合并、删除等操作可通过索引来向指定位置插入元素可通过pop()方法删除末尾元素,pop(索引位置)来删除指
2023-01-30

python二维数组怎么按列排序

在Python中,可以使用sorted函数和lambda函数来按列对二维数组进行排序。下面是一个示例代码:# 二维数组matrix = [[5, 2, 3],[1, 7, 6],[4, 8, 9]]# 定义按列排序的函数def sor
python二维数组怎么按列排序
2024-02-29

Python通过内置函数和自写算法DFS实现排列组合

这篇文章主要介绍了Python通过内置函数和自写算法DFS实现排列组合,排列组合是数学中的一种常见的计算方法,用于求出从给定的元素中选取若干个元素的所有可能的排列或组合。在Python中,有多种方式可以实现排列组合的计算,需要的朋友可以参考下
2023-05-18

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录