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

dfs(二十一)46. 全排列 中等

46. 全排列

给定一个不含重复数字的数组 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]]

提示:

  • 1 <= nums.length <= 6
  • -10 <= nums[i] <= 10
  • nums 中的所有整数 互不相同

 

class Solution {
public:
    vector<vector<int>> res; 用来存储每一条合理路径
    vector<int> path; 用来记录当前路径
    bool book[7] = {false}; 用于标记访问过的元素
    vector<vector<int>> permute(vector<int>& nums) {
        dfs(nums);
        return res;
    }
    void dfs(vector<int>& nums)
    {
        if(path.size() == nums.size())
        {
            res.push_back(path);
            return;
        }

        for(int i = 0; i < nums.size(); i++)
        {
            if(!book[i])
            {
                book[i] = true;
                path.push_back(nums[i]);
                dfs(nums);

                回溯:恢复现场
                book[i] = false;
                path.pop_back();
            }
        }
    }
};

相关文章:

  • 【Linux】信号:产生信号
  • 夜莺监控 v8.0 新版通知规则 | 对接飞书告警
  • 【数据分析】数据筛选与访问行列元素3
  • VLLM专题(十九)—兼容 OpenAI 的服务器
  • [极客大挑战 2019]Http_3.19BUUCTF练习day3(1)
  • 聚类算法api初步使用
  • ArcGIS10.X影像智能下载!迁移ArcGIS Pro批量智能高清影像下载工具至ArcGIS!
  • 音频进阶学习二十——DFT离散傅里叶变换
  • html相关常用语法
  • 【docker】--- 详解 WSL2 中的 Ubuntu 和 Docker Desktop 的区别和关系!
  • springboot Actuator 指标分析
  • 在 Kubernetes(k8s)部署过程中常见的问题
  • 数据结构:用C语言实现插入排序
  • WPF 中的 GridSplitter 详解
  • mysql 索引的使用
  • 【数据库备份】docker中数据库备份脚本——MySql备份脚本
  • 【工具分享】vscode+deepseek的接入与使用
  • Spring MVC响应数据
  • Redis Spring Cache
  • 一和零 (leetcode 474
  • 成都公积金新政征求意见:购买保障性住房最高贷款额度上浮50%
  • 调节负面情绪可以缓解慢性疼痛
  • 暴雨蓝色预警:南方开启较强降雨过程
  • 印媒证实:至少3架印军战机7日在印控克什米尔地区坠毁
  • “注胶肉”或已泛滥?这几种肉,再爱吃也要管住嘴
  • 解锁川北底色密码,“文化三地”志愿宣讲员招募计划启动报名