46.全排列

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

java 复制代码
class Solution {

    List<List<Integer>> res = new ArrayList<>();

    List<Integer> temp = new ArrayList<>();

    public List<List<Integer>> permute(int[] nums) {
        List<Integer> list = new ArrayList<>();
        backtrace(nums, list);
        return res;
    }

    // 用list记录添加过的下标。
    public void backtrace(int[] nums, List<Integer> list){
        if(list.size() == nums.length){
            res.add(new ArrayList(temp));
            return;
        }
        for(int i = 0; i < nums.length; i++){
            int num = nums[i];
            if(!list.contains(num)) {
                temp.add(num);
                list.add(num);
            } else continue;
            backtrace(nums, list);
            temp.remove(temp.size() - 1);
            list.remove(list.size() - 1);
        }
    }
    
}

其实可以直接不记录list,使用nums不重复的特性,在temp中判断是否加入过某个元素:

java 复制代码
class Solution {

    List<List<Integer>> res = new ArrayList<>();

    List<Integer> temp = new ArrayList<>();

    public List<List<Integer>> permute(int[] nums) {
        backtrace(nums);
        return res;
    }

    public void backtrace(int[] nums){
        if(temp.size() == nums.length){
            res.add(new ArrayList(temp));
            return;
        }
        for(int i = 0; i < nums.length; i++){
            // 因为nums不重复!
            int num = nums[i];
            if(!temp.contains(num)) {
                temp.add(num);
            } else continue;
            backtrace(nums);
            temp.remove(temp.size() - 1);
        }
    }   
}
相关推荐
DdduZe几秒前
8.19作业
数据结构·算法
PyHaVolask5 分钟前
链表基本运算详解:查找、插入、删除及特殊链表
数据结构·算法·链表
高山上有一只小老虎5 分钟前
走方格的方案数
java·算法
吧唧霸14 分钟前
golang读写锁和互斥锁的区别
开发语言·算法·golang
1白天的黑夜11 小时前
链表-2.两数相加-力扣(LeetCode)
数据结构·leetcode·链表
花火|1 小时前
算法训练营day55 图论⑤ 并查集理论基础、107. 寻找存在的路径
算法·图论
花火|1 小时前
算法训练营day56 图论⑥ 108. 109.冗余连接系列
算法·图论
上海迪士尼352 小时前
力扣子集问题C++代码
c++·算法·leetcode
花开富贵ii2 小时前
代码随想录算法训练营四十六天|图论part04
java·数据结构·算法·图论