(补)算法刷题Day19:BM55 没有重复项数字的全排列

题目链接

给出一组数字,返回该组数字的所有排列

例如:

[1,2,3]的所有排列如下

[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2], [3,2,1].

(以数字在数组中的位置靠前为优先级,按字典序排列输出。)

思路:

使用回溯,每次选择一个数字,画出回溯二叉树。回溯的过程中,如果收集过该元素,就跳过,不用对其进行回溯。我这里是通过该元素是否在path数组中出现过来筛选的,也可以用通用一点的used数组记录哪些元素被使用过。(这个used在Day20的题目用到)。

代码

python 复制代码
import copy

result = [] # 全局元素,记录收集好的路径
def traverse(nums, path):
    if len(path) == len(nums): // 当收集的路径长度等于num长度时,即为收集好了
        tmp = copy.deepcopy(path) // 注意,一定要使用深拷贝
        result.append(tmp)
        return
    for i in range(len(nums)):
        if nums[i] in path: //如果收集过,就跳过。用是否在数组中出现过来筛选。
            continue
        else:
            path.append(nums[i])
            traverse(nums, path)
            path.pop()

class Solution:
    def permute(self, num: List[int]) -> List[List[int]]:
        traverse(num, [])
        return result

隔三差五还债,终于忙完家里的事情,有精力去刷题了

相关推荐
鸿蒙开天组●2 分钟前
华为OD机考题加答案之输出指定位置的数字
数据结构·华为od·华为·harmonyos·鸿蒙
Z-xina4 分钟前
Python面试常见问题及答案6
python
arnold665 分钟前
华为OD E卷(100分)22-机器人的活动区域
算法·华为od
海阔天空_201310 分钟前
Python-pptx库简介
开发语言·python·自动化
老歌老听老掉牙10 分钟前
python之求平面离散点集围成的面积
python·平面·面积·鞋带公式
arnold6629 分钟前
华为OD E卷(100分)16-智能成绩表
数据结构·算法·华为od
半夏知半秋33 分钟前
Python学习-数据结构
开发语言·数据结构·笔记·python·学习
zhlh_xt37 分钟前
从零开始:在PyCharm中手动构建可靠的Python虚拟环境
python·pycharm·virtualenv·虚拟环境手动创建
belldeep39 分钟前
python:用 sklearn SVM 构建分类模型,并评价
python·分类·sklearn·metrics
zhlh_xt40 分钟前
Python 助力 DBA:高效批量管理数据库服务器的多线程解决方案-多库查询汇总工具实现
数据库·python·sqlserver·dba·dba 自动化工具