(补)算法刷题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

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

相关推荐
大数据魔法师3 分钟前
豆瓣图书数据采集与可视化分析(四)- 豆瓣图书数据可视化(Pyecharts)
python·数据分析·数据可视化
databook18 分钟前
掌握ChangeSpeed类:让数学动画速度随心而动!
python·动效
水花花花花花20 分钟前
蓝桥杯国赛前一晚知识点准备(十六届python)
前端·javascript·python
Javis21122 分钟前
代码随想录算法训练营第三十二天 |【动态规划1-13】
算法
CS创新实验室26 分钟前
CPython 局部变量存储机制:从 “栈上存储“ 看语言实现差异
python···cpython·局部变量
程序员Xu27 分钟前
【大厂机试题解法笔记】恢复数字序列
笔记·算法·深度优先
Python当打之年1 小时前
【61 Pandas+Pyecharts | 基于Apriori算法及帕累托算法的超市销售数据分析可视化】
python·信息可视化·数据分析·pandas·数据可视化
苏三福1 小时前
yolo11-seg 推理测试infer
python·opencv·计算机视觉
熊猫钓鱼>_>1 小时前
Django全栈开发实战与架构思考
python·架构·django
r0ysue_1 小时前
03.利用显卡内核模块等特性为算法提速百倍
人工智能·python·机器学习