0

0

Python全排列怎么生成_itertools.permutations与回溯法

P粉602998670

P粉602998670

发布时间:2026-03-12 08:03:57

|

520人浏览过

|

来源于php中文网

原创

itertools.permutations最省事但返回迭代器,需转list查看;大数据应for循环逐个处理;不自动去重;回溯法可控制去重、剪枝,有两种实现方式。

python全排列怎么生成_itertools.permutations与回溯法

itertools.permutations 生成全排列最省事,但别直接 print

它返回的是迭代器,不是列表,直接 print(permutations([1,2,3])) 只会看到类似 <itertools.permutations object at></itertools.permutations> 的东西,啥也看不到。

  • 要立刻看结果,得转成 list:list(permutations([1,2,3]))
  • 如果数据大(比如长度 >10),别无脑转 list,内存会爆;该用 for 循环逐个处理:for p in permutations(items): process(p)
  • 它对重复元素不自动去重,permutations([1,1,2]) 会返回 6 个结果,其中含重复排列(因为内部按位置区分)

回溯法手写全排列,关键在“交换 + 恢复”或“路径 + used 数组”

想控制去重、剪枝、或理解原理,就得自己写。两种主流写法,区别在状态管理方式:

  • 用索引交换(原地修改):每次把 i 到末尾的每个元素换到当前位置,递归后必须 swap 回来,否则后续分支错乱
  • pathused 数组(更直观):每次选一个未用过的元素追加到 path,递归完从 path 弹出,used[i] 设回 False
  • 去重前提:输入先排序,然后跳过 nums[i] == nums[i-1] and not used[i-1] 这种情况(保证相同元素按顺序填入)

性能差一倍?别在循环里反复调用 list(permutations(...))

每次调用 permutations 都新建迭代器,但真正耗时的是后续遍历。常见低效写法:

Kacha
Kacha

KaCha是一款革命性的AI写真工具,用AI技术将照片变成杰作!

下载
  • 错误:在 for 循环里反复写 for p in list(permutations(arr)): ... —— 每次都重新生成全部排列再转 list
  • 正确:只生成一次,存变量:perms = list(permutations(arr)),再遍历 perms
  • 回溯法若没剪枝,时间复杂度固定是 O(n!),和 itertools 一样;但它的常数更大(函数调用、列表拷贝等),小数据看不出,n=10 以上就明显慢

字符串、元组、自定义对象也能排,但注意不可变类型限制

permutations 不关心内容类型,只按序列长度和索引操作。但实际用时容易卡住:

立即学习Python免费学习笔记(深入)”;

  • 传字符串:permutations('abc') 返回的是 ('a','b','c') 这样的元组,拼成字符串得 ''.join(p)
  • 传元组或 namedtuple:没问题,但结果仍是元组,不能直接修改
  • 传 list 嵌套 list:会按外层 list 的元素排列,不会 flatten;想排内层元素得先 flatten 或单独处理
  • 回溯法里如果传 mutable 对象(如 list)进递归并原地改,记得深拷贝 path.copy() 再 append,否则所有结果指向同一份内存
真正难的不是写出全排列,是想清楚你要的是「所有排列」还是「所有不重复排列」,以及是否需要中途中断、带条件筛选、或和其它逻辑嵌套。这些地方一动,itertools 就不够用了,回溯的结构弹性才体现出来。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
python中print函数的用法
python中print函数的用法

python中print函数的语法是“print(value1, value2, ..., sep=' ', end=' ', file=sys.stdout, flush=False)”。本专题为大家提供print相关的文章、下载、课程内容,供大家免费下载体验。

192

2023.09.27

python print用法与作用
python print用法与作用

本专题整合了python print的用法、作用、函数功能相关内容,阅读专题下面的文章了解更多详细教程。

18

2026.02.03

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

760

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

221

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1566

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

649

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

1228

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

1184

2024.04.29

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 4.9万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号