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

1. 排列问题

题目

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

思路

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

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

终止条件:收集元素的数组大小和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;
        }
    }
相关推荐
bIo7lyA8v18 分钟前
算法可视化对教学与调试效率的影响分析的技术8
算法
hunterkkk(c++)27 分钟前
优先队列启发式最短路径快速算法(优化SPFA)-HEAP_SPFA算法
算法
SiliconGazer40 分钟前
第15届国赛满分代码解析(下)—— 运动轨迹算法、按键交互与完整状态机
算法·状态机·stc15f2k60s2·浮点运算·蓝桥杯国赛·运动轨迹、·向量分解
Navigator_Z41 分钟前
LeetCode //C - 1096. Brace Expansion II
c语言·算法·leetcode
luj_176843 分钟前
FreeDOS vs MS-DOS PC-DOS 对比解析
服务器·c语言·开发语言·经验分享·算法
RH2312111 小时前
2026.6.10 数据结构 二叉树
数据结构
笨笨没好名字1 小时前
Leetcode刷题python版第一周
python·算法·leetcode
Cthy_hy1 小时前
斯特林数:组合划分的递归经典,一二两类全解
python·算法·斯特林数
不忘不弃1 小时前
计算pi的近似值
算法
码云骑士1 小时前
12-GIL不是性能杀手(下)-绕过GIL的三种方案与决策树
算法·决策树·机器学习