python之排列组合1

排列组合

不重复全排列

给定一个可包含重复数字的序列nums,按任意顺序返回所有不重复的全排列

示例1:

输入:nums=[1,1,2]

输出:[[1,1,2], [1,2,1], [2,1,1]]

输入:nums=[1,2,3]

输出:[[1,2,3], [1,3,2], [2,1,3], [2,3,1], [3,1,2], [3,2,1]]

思路:

1,对所有的列表元素进行全排列

2,删除重复排列的元素

复制代码
from typing import List  # 导入列List模块


class Solution:  # 建立类
    def combination(self, nums: List[int]):  # 定义函数,并定义输入格式
        if len(nums) == 0:  # 如果为空列表则返回空[]
            return []
        elif len(nums) == 1:  # 如果列表只有一个项,则返回列表本身
            return [nums]  # 一定要用[nums]-返回列表,return nums则是返回列表的value
        else:
            ans = []  # 建立空列表,用于存储中间值
            for index, item in enumerate(nums):  # 遍历列表的索引及值
                rel = nums[:index] + nums[index + 1:]  # 提取除了当前项的以外的nums列表
                print('index:', index, 'item:', item)  # 打印输出索引及值,此输出为中间步骤输出方便理解,可以注释掉
                print('rel:', rel)  # 打印剔除当前项以外的列表,此输出为中间步骤输出方便理解,可以注释掉
                for j in self.combination(rel):  # 递归调用,
                    ans.append(j + [item])  # 形成新的组合
                    print(ans)  # 此输出为中间步骤输出方便理解,可以注释掉
            result = []  # 输出结果的空列表
            for i in ans:  # 遍历ans中间存储列表
                if i not in result:  # 去重,不同排列的组合存在result列表中,重复项目不保存
                    result.append(i)
            return result


list_1 = []
s = Solution()
print(s.combination(list_1))
print('----1')
list_1 = [1, 1]
print(s.combination(list_1))
print('----2')
list_1 = [1, 1, 2]
print(s.combination(list_1))
print('----3')
相关推荐
joshchen2152 分钟前
强化学习基础(赵世钰)第二章 贝尔曼方程
人工智能·python·机器学习·强化学习
小妖同学学AI4 分钟前
架构图即代码:GitHub星标41.9k的Diagrams,用Python解放你的画图生产力
开发语言·python·github
第一程序员10 分钟前
2026年Python就业市场分析:非科班转码者的机会与挑战
python·github
Thanks_ks11 分钟前
【第 002 讲】Python 标准开发环境搭建:运行环境 | 环境变量 | IDE 部署 | 配置优化
ide·python·pycharm·开发工具·环境配置·环境变量·编程基础
雷帝木木11 分钟前
Python 中的配置文件管理:从基础到高级应用
人工智能·python·深度学习·机器学习
郝学胜-神的一滴12 分钟前
Python 鸭子类型:优雅的多态哲学,让代码更自由
linux·服务器·开发语言·python·网络协议
小龙报13 分钟前
【必装软件】python及pycharm的安装与环境配置
开发语言·人工智能·python·语言模型·自然语言处理·pycharm·语音识别
QQ_18808380013 分钟前
python+flask+vue在线宠物医疗预约平台的设计与实现_b5z03zls
vue.js·python·flask
星辰徐哥13 分钟前
Python 基础与环境配置
开发语言·python
雷帝木木17 分钟前
Python元编程高级技巧:深入理解代码生成与动态行为
人工智能·python·深度学习·机器学习