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

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

相关推荐
老毛肚21 小时前
jeecg-boot-base-core 02 day
javascript·python
yaoxin52112321 小时前
434. Java 日期时间 API - Period 基于日期的时间段
java·开发语言·python
noipp21 小时前
推荐题目:洛谷 P10907 [蓝桥杯 2024 国 B] 蚂蚁开会
c语言·c++·算法·编程·洛谷
岁月宁静1 天前
RAG 文档摄入全链路,从原理到生产落地
vue.js·人工智能·python
程序员二叉1 天前
【JUC】线程池全套深度详解|参数|流程|拒绝策略|调优|异常处理
java·开发语言·jvm·算法·面试·juc
JaydenAI1 天前
[对比学习LangChain和MAF-07]如何引入人机交互的审批流程
python·ai·langchain·c#·agent·hitl·maf
青山木1 天前
Hot 100 --- 轮转数组
java·数据结构·算法
徐小夕1 天前
Loop Engineering 深度解析与实战指南(全网最全)
前端·算法·github
神奇元创1 天前
商用级光路加速卡:大模型推理的极速落地方案
python·神经网络·fpga开发·dsp开发