当前位置: 首页 > news >正文

【练习】【排列No.1】力扣46. 全排列

题目

  1. 全排列

给定一个不含重复数字的数组 nums ,返回其 所有可能的全排列 。你可以 按任意顺序 返回答案。

示例 1:

输入:nums = [1,2,3]

输出:[[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1]]

示例 2:

输入:nums = [0,1]

输出:[[0,1],[1,0]]

示例 3:

输入:nums = [1]

输出:[[1]]

来源:力扣46. 全排列


思路(注意事项)

利用used数组判断一枝有无重复元素


纯代码

class Solution {
private:
    vector<vector<int>> ans;
    vector<int> path;
    void backtracking(vector<int>& nums, vector<bool>& used)
    {
        if (path.size() == nums.size())
        {
            ans.push_back(path);
            return;
        }
        for (int i = 0; i < nums.size(); i ++)
        {
            if (used[i] == true) continue;
            used[i] = true;
            path.push_back(nums[i]);
            backtracking(nums,used);
            used[i] = false;
            path.pop_back();
        }
    }
public:
    vector<vector<int>> permute(vector<int>& nums) {
        vector<bool> used(nums.size(), false);
        backtracking(nums, used);
        return ans;
    }
};

题解(加注释)

class Solution {
private:
    vector<vector<int>> ans;  // 存储所有排列的结果
    vector<int> path;         // 存储当前递归路径中的排列

    // 回溯函数,用于生成所有排列
    void backtracking(vector<int>& nums, vector<bool>& used) {
        // 如果当前路径中的排列长度等于 nums 的长度,将其加入结果
        if (path.size() == nums.size()) {
            ans.push_back(path);
            return;
        }

        // 遍历数组中的每一个元素
        for (int i = 0; i < nums.size(); i++) {
            // 如果当前元素已经被使用过,跳过
            if (used[i] == true) continue;

            // 标记当前元素为已使用
            used[i] = true;

            // 将当前元素加入路径
            path.push_back(nums[i]);

            // 递归调用,继续生成排列
            backtracking(nums, used);

            // 回溯:撤销当前选择,尝试其他可能性
            used[i] = false;

            // 将当前元素从路径中移除
            path.pop_back();
        }
    }

public:
    // 主函数,生成输入数组的所有排列
    vector<vector<int>> permute(vector<int>& nums) {
        // 初始化 used 数组,用于标记元素是否被使用
        vector<bool> used(nums.size(), false);

        // 从空路径开始回溯
        backtracking(nums, used);

        // 返回所有排列
        return ans;
    }
};

相关文章:

  • 第十七:嵌套路由
  • 【AutoSar】DeepSeek回答什么是IO抽象
  • 协方差(Covariance)与得分函数:从Fisher信息矩阵看统计关联
  • 在 Mac mini M2 上本地部署 DeepSeek-R1:14B:使用 Ollama 和 Chatbox 的完整指南
  • C#中提供的多种集合类以及适用场景
  • 危化品经营单位安全管理人员的职责及注意事项
  • 数字IC后端设计实现OCC(On-chip Clock Controller)电路介绍及时钟树综合案例
  • 无人机实战系列(三)本地摄像头+远程GPU转换深度图
  • 4 算法1-3 三连击(升级版)
  • 《机器学习数学基础》补充资料:欧几里得空间的推广
  • 模电学习资料汇总
  • 力扣-贪心-452 用最小数量的箭引爆气球
  • ViT 模型介绍(二)——模型架构
  • 第4章 4.4 EF Core数据库迁移 Add-Migration UpDate-Database
  • Vue.js组件开发:从基础到进阶
  • 【LeetCode18】四数之和
  • 【论文学习】基于规模化Transformer模型的低比特率高质量语音编码
  • python与C系列语言的差异总结(1)
  • 玩机日记 10 fnOS 开启文件传输服务挂载到手机/电脑,测试传输性能
  • 设置 C++ 开发环境
  • 首届中国人文学科年度发展大会启幕,共话AI时代人文使命
  • 菲律宾选举委员会公布中期选举结果,马科斯阵营选情未达预期
  • 浙江一家长称小学老师打孩子还威胁要从3楼扔下,当地警方已立案
  • 外企聊营商|上海仲裁:化解跨国企业纠纷的“上海路径”
  • 美国务卿鲁比奥抵达会场,将参加俄乌会谈
  • 侵害孩子者,必严惩不贷!3名性侵害未成年人罪犯今日执行死刑