算法通关18关 | 回溯模板如何解决排列和单词搜索问题

1. 排列问题

题目

LeetCode46 给定一个没有重复数字的序列,返回其所有可能的全排列,

思路

排列问题的思路同样使用与字母大小写全排列LeetCode784。

元素在使用过一次的时候,在图中第二层的时候,还会再被使用,所以能用startIndex了,使用used[i]数组来标记已经选择的元素。过程如图示。

终止条件:收集元素的数组大小和nums数组的大小一样大的时候,就找到了一个全排列

代码

java 复制代码
    /**
     * 排列问题,同样适用于字母大小写全排列
     */
     List<List<Integer>> res = new ArrayList<>();

      LinkedList<Integer> path = new LinkedList<>();
    boolean[] used;

    public  List<List<Integer>> permure(int[] nums){
        if (nums.length == 0){
            return res;
        }
        used = new boolean[nums.length];
        psermuteHelper(nums);
        return res;
    }

    private  void psermuteHelper(int[] nums) {
        if (path.size() == nums.length){
            res.add(new ArrayList<>(path));
            return;
        }
        for (int i = 0; i < nums.length; i++) {
            //为true的时候代表再纵向被使用过,纵向第一条元素出来的时候,会转为false
            if (used[i]){
                continue;
            }
            used[i] = true;
            path.add(nums[i]);
            psermuteHelper(nums);
            path.removeLast();
            used[i] = false;
        }
    }
相关推荐
byzh_rc1 分钟前
[算法设计与分析-从入门到入土] 分治法
算法
拉拉拉拉拉拉拉马9 分钟前
感知机(Perceptron)算法详解
人工智能·python·深度学习·算法·机器学习
falldeep9 分钟前
LeetCode高频SQL50题总结
数据结构·数据库·sql·算法·leetcode·职场和发展
CoderCodingNo10 分钟前
【GESP】C++五级真题(前缀和思想考点) luogu-P10719 [GESP202406 五级] 黑白格
开发语言·c++·算法
zore_c10 分钟前
【C语言】排序算法——希尔排序以及插入排序 ——详解!!!
c语言·数据结构·c++·笔记·算法·排序算法·推荐算法
C雨后彩虹11 分钟前
ConcurrentHashMap 扩容机制:高并发下的安全扩容实现
java·数据结构·哈希算法·集合·hashmap
Chip Design17 分钟前
量子–经典混合计算生态:量子启发式、量子模拟、经典算法
算法·量子计算
BB学长19 分钟前
Icepak|01功能介绍
算法·数学建模·能源·微信公众平台
Cathy Bryant20 分钟前
傅里叶变换(二):旋转楼梯
笔记·算法·数学建模·信息与通信·傅里叶分析
2401_8414956422 分钟前
【LeetCode刷题】零钱兑换
数据结构·python·算法·leetcode·动态规划·数组·时间复杂度