当前位置: 首页 > article >正文

递归练习三(决策树)

一、解题心得

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

二、例题

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 来记录每一层递归的路径,当然只要在本层修改路径,回溯时就一定要把路径还原,这样才能让下一次递归有正确的路径。


http://www.kler.cn/a/511382.html

相关文章:

  • 网络安全 | 什么是正向代理和反向代理?
  • AIGC视频生成模型:Meta的Emu Video模型
  • 【Cadence tip】噪声仿真方法
  • C++,设计模式,【目录篇】
  • HighCharts 交互式图表-01-入门介绍
  • 【Python运维】用Python管理Docker容器:从`docker-py`到自动化部署的全面指南
  • 53,【3】BUUCTF WEB october 2019 Twice SQLinjection
  • 82.提取条件模式
  • BUUCTF_Web([GYCTF2020]Ezsqli)
  • Linux中的文件上传和下载
  • 前后端分离的Java快速开发平台
  • 【万图找码】在大量图片中快速找出有二维码的图片
  • TP4056锂电池充放电芯片教程文章详解·内置驱动电路资源!!!
  • Web3 时代,区块链与物联网的融合创新前景
  • Axios 封装:处理重复调用与内容覆盖问题
  • node_exporter 集成Prometheus+Grafana
  • ingress-nginx代理tcp使其能外部访问mysql
  • reac 后端接口返回二进制文件流前端导出文件
  • 主控制器与子模块通讯协议
  • 要获取本地的公网 IP 地址(curl ifconfig.me)
  • 【Compose multiplatform教程】05 IOS环境编译
  • Linux(DISK:raid5、LVM逻辑卷)
  • 基于GRU实现股价多变量时间序列预测(PyTorch版)
  • 数据结构-顺序表链表经典OJ题
  • RabbitMQ集群安装rabbitmq_delayed_message_exchange
  • 【数据库知识】PostgreSQL介绍