(leetcode学习)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 中的所有整数 互不相同

dfs就完事了,慢是慢了点

最多就6个数排列,可以考虑打表;

cpp 复制代码
class Solution {
public:
    vector<vector<int>> res;

    void dfs(vector<int>& nums, int cur_n, vector<int>& cur_res){
        if(cur_n == nums.size()){
            vector<int> temp(cur_res);
            res.push_back(temp);
            return ;
        }

        int k = cur_res.size();
        for(int i = 0; i<=k; i++){
            cur_res.insert(i + cur_res.begin(), nums[cur_n]);
            dfs(nums, cur_n+1, cur_res);
            cur_res.erase(i + cur_res.begin());
        }
    }

    vector<vector<int>> permute(vector<int>& nums) {
        vector<int> temp;
        temp.push_back(nums[0]);
        dfs(nums, 1, temp);
        return res;
    }
};
相关推荐
玉树临风江流儿8 分钟前
C++左值、右值、move移动函数
开发语言·c++
王哈哈^_^8 分钟前
YOLOv11视觉检测实战:安全距离测算全解析
人工智能·数码相机·算法·yolo·计算机视觉·目标跟踪·视觉检测
..Cherry..21 分钟前
Etcd详解(raft算法保证强一致性)
数据库·算法·etcd
商汤万象开发者37 分钟前
LazyLLM教程 | 第13讲:RAG+多模态:图片、表格通吃的问答系统
人工智能·科技·算法·开源·多模态
Lee_yayayayaya1 小时前
本原多项式产生m序列的原理
算法
民乐团扒谱机1 小时前
实验室安全教育与管理平台学习记录(七)网络安全
学习·安全·web安全
许长安1 小时前
c/c++ static关键字详解
c语言·c++·经验分享·笔记
蒙奇D索大1 小时前
【11408学习记录】考研英语长难句精析:三步拆解真题复杂结构,轻松攻克阅读难关!
笔记·学习·考研·改行学it
Murphy_lx2 小时前
C++ thread类
开发语言·c++
月夜的风吹雨2 小时前
【C++ STL 深度剖析】:vector 底层模拟实现与核心陷阱解析
c++·vector·类和对象·visual studio