回溯算法——排列篇

目录

一、全排列

二、全排列II


一、全排列

46. 全排列 - 力扣(LeetCode)

java 复制代码
class Solution {
    List<List<Integer>> result=new ArrayList<>();
    LinkedList<Integer> path=new LinkedList<>();
    boolean[] used;
    public List<List<Integer>> permute(int[] nums) {
        used=new boolean[nums.length];
        backtracking(nums);
        return result;
    }
    public void backtracking(int[] nums){
        if(path.size()==nums.length){
            result.add(new ArrayList<>(path));
            return;
        }
        for(int i=0;i<nums.length;i++){
            if(used[i])continue;
            used[i]=true;
            path.add(nums[i]);
            backtracking(nums);
            path.removeLast();//移除最后一个添加的元素
            used[i]=false;//元素修改为未使用
        }
    }
}

二、全排列II

47. 全排列 II - 力扣(LeetCode)

java 复制代码
class Solution {
    List<List<Integer>> result=new ArrayList<>();
    List<Integer> path=new ArrayList<>();
    public List<List<Integer>> permuteUnique(int[] nums) {
        boolean[] used=new boolean[nums.length];
        Arrays.fill(used,false);
        Arrays.sort(nums);
        backtracking(nums,used);
        return result;
    }
    public void backtracking(int[] nums,boolean[] used){
        if(path.size()==nums.length){
            result.add(new ArrayList<>(path));
            return;
        }
        for(int i=0;i<nums.length;i++){
            if(i>0&&nums[i]==nums[i-1]&&used[i-1]==true)continue;
            if(used[i]==false){
                used[i]=true;
                path.add(nums[i]);
                backtracking(nums,used);
                path.removeLast();
                used[i]=false;
            }
        }
    }
}
相关推荐
努力学习的小廉18 分钟前
我爱学算法之—— 分治-快排
c++·算法
未知陨落19 分钟前
LeetCode:77.买卖股票的最佳时机
算法·leetcode
DeeGLMath22 分钟前
排序算法的并行加速实现
算法·排序算法·joblib·sortingx
机器学习之心1 小时前
量子遗传算法是一种将量子计算原理与遗传算法相结合的智能优化算法,代表了进化计算的一个有趣分支
算法·量子计算
Miraitowa_cheems1 小时前
LeetCode算法日记 - Day 59: 字母大小写全排列、优美的排列
java·数据结构·算法·leetcode·决策树·职场和发展·深度优先
未知陨落2 小时前
LeetCode:81.爬楼梯
算法·leetcode
SHtop112 小时前
排序算法(golang实现)
算法·golang·排序算法
Rain_is_bad3 小时前
初识c语言————数学库函数
c语言·开发语言·算法
艾醒4 小时前
大模型面试题剖析:模型微调中冷启动与热启动的概念、阶段与实例解析
深度学习·算法
新学笺5 小时前
数据结构与算法 —— 从基础到进阶:带哨兵的单向链表,彻底解决边界处理痛点
算法