(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;
    }
};
相关推荐
6230_23 分钟前
关于HTTP通讯流程知识点补充—常见状态码及常见请求方式
前端·javascript·网络·网络协议·学习·http·html
Pandaconda1 小时前
【C++ 面试 - 新特性】每日 3 题(六)
开发语言·c++·经验分享·笔记·后端·面试·职场和发展
北南京海1 小时前
【C++入门(5)】类和对象(初始类、默认成员函数)
开发语言·数据结构·c++
阿拉伯的劳伦斯2921 小时前
LeetCode第一题(梦开始的地方)
数据结构·算法·leetcode
Mr_Xuhhh1 小时前
C语言深度剖析--不定期更新的第六弹
c语言·开发语言·数据结构·算法
Yusei_05231 小时前
C++基础知识6 vector
开发语言·c++
日记成书1 小时前
【无线通信发展史⑨】1791年路易吉·伽伐尼-关于动物电的研究与1800年亚历山大·伏打伯爵-电池:伏打电池
网络·人工智能·学习·职场和发展·信息与通信
黄卷青灯772 小时前
c++ 定义类 介绍
开发语言·c++·定义类
贾saisai2 小时前
Xilinx系FPGA学习笔记(四)VIO、ISSP(Altera)及串口学习
笔记·学习·fpga开发
伍心2 小时前
004: VTK读入数据---vtkImageData详细说明
c++·windows·microsoft·mfc·软件工程·visual studio