【LeetCode热题100(54/100)】全排列

题目地址: 链接

思路: 通过递归 + 回溯方式实现 全排列

js 复制代码
/**
 * @param {number[]} nums
 * @return {number[][]}
 */
var permute = function(nums) {
    let n = nums.length;
    let vited = new Array(n).fill(false);

    let ans = [];
    const dfs = (idx, arr) => {
        if(idx == n) {
            ans.push(arr);
            return;
        }
        for(let i = 0; i < nums.length; i ++) {
            if(vited[i]) continue;
            vited[i] = true;
            dfs(idx + 1, [...arr, nums[i]]);
            vited[i] = false;
        }
    }
    dfs(0, []);
    return ans;
};
相关推荐
yyy(十一月限定版)17 小时前
matlab矩阵的操作
算法·matlab·矩阵
努力学算法的蒟蒻17 小时前
day58(1.9)——leetcode面试经典150
算法·leetcode·面试
txinyu的博客17 小时前
map和unordered_map的性能对比
开发语言·数据结构·c++·算法·哈希算法·散列表
搞笑症患者17 小时前
压缩感知(Compressed Sensing, CS)
算法·最小二乘法·压缩感知·正交匹配追踪omp·迭代阈值it算法
im_AMBER17 小时前
Leetcode 101 对链表进行插入排序
数据结构·笔记·学习·算法·leetcode·排序算法
快手技术18 小时前
AAAI 2026|全面发力!快手斩获 3 篇 Oral,12 篇论文入选!
前端·后端·算法
颜酱18 小时前
前端算法必备:滑动窗口从入门到很熟练(最长/最短/计数三大类型)
前端·后端·算法
做科研的周师兄18 小时前
【MATLAB 实战】栅格数据 K-Means 聚类(分块处理版)—— 解决大数据内存溢出、运行卡顿问题
人工智能·算法·机器学习·matlab·kmeans·聚类
X在敲AI代码18 小时前
leetcodeD3
数据结构·算法
踩坑记录18 小时前
leetcode hot100 560.和为 K 的子数组 medium 前缀和 + 哈希表
leetcode