全排列算法

发布于 2023-05-05 20:57:21 字数 680 浏览 60 评论 0

给定一个 没有重复 数字的序列,返回其所有可能的全排列。

示例:
输入: [1,2,3] 输出: [ [1,2,3], [1,3,2], [2,1,3], [2,3,1], [3,1,2], [3,2,1] ]

使用 dfs

var permute = function(nums) {
    let res = [];
    let visited = new Array(nums.length).fill(false);
    dfs(nums, [], visited, res);
    return res;
};

function dfs(nums, path, visited, res) {
    if (path.length === nums.length) {
        res.push([...path]);
        return;
    }
    for (let i = 0; i < nums.length; i++) {
        if (visited[i]) continue;
        visited[i] = true;
        path.push(nums[i]);
        dfs(nums, path, visited, res);
        path.pop();
        visited[i] = false;
    }
}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

文章
评论
814 人气
更多

推荐作者

櫻之舞

文章 0 评论 0

弥枳

文章 0 评论 0

m2429

文章 0 评论 0

野却迷人

文章 0 评论 0

我怀念的。

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文