递归练习三(决策树)

一、解题心得

当我们需要暴力搜索全部的解时可以考虑用递归,解决方法就是画出决策树,由于二叉树的性质可以知道二叉树的分支代表两种情况,此时如果画出所有情况就是画出了决策树,又由于树的遍历用的是递归,所以就可以遍历决策树来添加出所有的解。

二、例题

1、全排列

46. 全排列 - 力扣(LeetCode)

分析

全排列可以有两种方法

(1)按位解决

顾名思义就是分析每一位上是什么数字。要求就是前面出现的数字在这一位上不能再出现。按位解决可以画出决策树:

(2)按层解决

规定第 n 层只能有 n 个数字

n 数的全排列就是在 n - 1 数全排列的基础上,把第 n 个数插入到每一个 n - 1 数全排列数组的 n 个位置

举例:[1, 2, 3]

1

12 21

312 231 123 321 231 213

代码

(1)按位解决

(2)按层解决

2、子集

78. 子集 - 力扣(LeetCode)

分析

有三种解决办法,两种决策树,一种按层解决

(1)决策树1

子集与全排列的区别就是全排列每一位必须选,子集每一位可以选可以不选。

由此第一种决策树结果出现在叶子节点。

决策树:

(2)决策树2

递归到数 i 的时候,i 以及 i 之后的值也是可以加入到之前存好的路径的,所以每一次的加入都是一个新的结果。

决策树:

(3)按层解决

规定第 n 层只能有 n 个数字

为了保证每层添加数字时不重不漏,只会添加比前一个数大的数,即子集都是升序。

举例:[1, 2, 3]

1 2 3

12 13 23

123 空

代码

(1)决策树1

(2)决策树2

(3)按层解决

三、总结

用决策树解决问题时一般结果在根到叶子的路径上,叶子节点或就是递归的每一次。

所以有很多时候都是要用到全局变量 tmp 来记录每一层递归的路径,当然只要在本层修改路径,回溯时就一定要把路径还原,这样才能让下一次递归有正确的路径。

相关推荐
后来后来啊7 小时前
2026.1.19学习笔记
笔记·学习·算法
Tisfy7 小时前
LeetCode 3314.构造最小位运算数组 I:今日先简单题简单做-到II再优化
算法·leetcode·题解·模拟·数组
AlenTech7 小时前
595. 大的国家 - 力扣(LeetCode)
算法·leetcode·职场和发展
橘颂TA7 小时前
【剑斩OFFER】算法的暴力美学——力扣 433 题:最小基因变化
数据结构·c++·算法·哈希算法
橘颂TA7 小时前
【剑斩OFFER】算法的暴力美学——力扣 1926 题:迷宫中离入口最近的出口
c++·算法·结构与算法
iAkuya7 小时前
(leetcode)力扣100 47从前序与中序遍历序列构造二叉树(迭代,递归)
算法·leetcode·职场和发展
smj2302_796826527 小时前
解决leetcode第3816题.删除重复字符后的字典序最小字符串
python·算法·leetcode
十八岁讨厌编程7 小时前
【算法训练营 · 二刷总结篇】 数组与字符串部分
算法
玖日大大7 小时前
随机森林算法原理及实战代码解析
算法·随机森林·机器学习
历程里程碑7 小时前
哈希1:两数之和:哈希表优化指南
java·开发语言·数据结构·c++·算法·哈希算法·散列表