python中的排列和组合_python 排列组合

116 篇文章 0 订阅
46 篇文章 0 订阅

前言

python中自带的排列:

itertools.permutations(iterable,r=None)

功能:连续返回由iterable序列中的元素生成的长度为r的排列

如果r未指定或为None,r默认设置未iterable的长度,即生成包含所有元素的全排列

from itertools import permutations
s = ['a','b','c']
for element in permutations(s,2):
    a = element[0] + element[1]
    # 或者这样写: a = ''.join(element)
    print(a,end=' ')
# 输出 ab ac ba bc ca cb 

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

s = [‘b’,‘a’,‘c’]的3个元素的位置是’b’=1、‘a’=2、‘c’=3,输出的排列"bac bca abc acd cba cad",按位置表示就是"123 132 213 231 312 321",这是按从小到大的顺序输出的。

python中自带的组合:

组合函数与排列函数相似,但是元素无序

from itertools import combinations
s = ['1','2','3']
for element in combinations(s,2):
    a = ''.join(element)
    print(a,end=' ')
# 输出 12 13 23 

由于自带的排列和组合效率比较低,所以我们需要进行手写排列组合,必要时进行剪枝等操作,进行优化。

手写排列和组合:

dfs参数有两种:一种是全局变量,另一种是形参

递归问题要手动画一个递归搜索树,有利于加深理解。

递归实现指数型枚举:

思路: 按顺序从1~n依次考虑每个数选与不选

n = int(input())
st = [0] * 16 # st 记录每一位的状态,选与不选
def dfs(u): # u 表示当前第几位
    if u == n:
        for i in range(n):
            if st[i] == 1:
                print(i+1,end=" ")
        print()
        return 
    st[u] = 1
    dfs(u+1)
    st[u] = 0
    dfs(u+1)
dfs(0)

递归实现排列型枚举:

思路1:依次枚举每个数放到哪个位置

思路2:依次枚举每个位置放哪个数

n = int(input())
st = [0] * (n+1)
used = [0] * (n+1)
def dfs(u): # 表示枚举到第几位
    if u > n:
        for i in range(1,n+1):
            print(st[i],end = ' ')
        print()
        return
    for i in range(1,n+1): # 依次枚举每个分支,即当前位置可以填哪些数
        if not used[i]:
            st[u] = i
            used[i] = 1
            dfs(u+1)
            st[u] = 0
            used[i] = 0
dfs(1)

递归实现组合型枚举:

在这里插入图片描述

思路:要求当前位置的下一位的位置不能小于当前位置

n,m = map(int,input().split())
st = [0] * 30
def dfs(u,start): # u 表示第几位(正在选第几位,已经选了u-1位),start表示从哪开始
    if u + n - start < m: # u - 1 + n - start + 1 < m 剪枝
        return 
    if u > m:
        for i in range(1,m+1):
            print(st[i],end = ' ')
        print()
        return
    for i in range(start,n+1):
        st[u] = i
        dfs(u+1,i+1)
        st[u] = 0
dfs(1,1)

-END-


Python入门全套学习资料附带源码:

全套软件安装包

附带完整的安装包的安装视频教程资源(新手大礼包已备好文末领取

在这里插入图片描述

整套零基础入门视频+课件笔记

img

👉实战案例👈

光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。
在这里插入图片描述

👉100道Python练习题👈

检查学习结果。

👉面试刷题👈

在这里插入图片描述

资料领取

上述这份完整版的Python全套学习资料已经上传网盘,朋友们如果需要可以微信扫描下方二维码输入“领取资料” 即可自动领取
或者

点此链接】领取

  • 29
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值