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

C++ dfs 的状态表示(五十一)【第十一篇】

今天我们接着学习dfs(状态表示)。

1.抽象形式的dfs

前面用到的 DFS 算法都是比较容易想象出搜索过程的,接下来我们看一些不那么容易想象搜索过程的 DFS 过程,这些问题我们称为抽象形式的 DFS。

来回顾一下上节课遇到的一个问题:

给定 
n 个整数,要求选出 K 个数,使得选出来的 K 个数的和为 sum。

我们依然借助 DFS 来解决这个问题。对于每一个数,枚举选或者不选两种情况,我们可以用 DFS 思想来完成这样的枚举过程。

我们在搜索的过程中,用 
S 来记录当前选择的数值总和,
k 来记录选择的数的个数,deep 表示当前正在枚举第几个数是否选择。

在第一层 DFS 的时候,我们可以枚举是否选第一个数,如果选第一个数则让 
S 加上第一个数且 
k 加一,DFS 进入到下一层;否则 DFS 直接进入到下一层。当然,这里我们还需要借助全局变量、参数或修改数组中元素的值等方式来标识出当前的层数,为了减少篇幅,在下文中就直接忽略掉了。

在第二层,对第二个数做同样的处理,DFS 的过程中记录已经选取的数的个数,如果已经选取了 k 个数,判断 
S 值是否等于sum。对于每一层,我们都有两个选择——选和不选。不同的选择,都会使得搜索进入完全不同的分支继续搜索。

下图是这个搜索过程对应的 搜索树,搜索树上的每一个结点都是一个 状态,一个状态包含两个值 S 和 k也就是一个状态对应当前的数值总和,以及选的数的个数。

图片


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

相关文章:

  • 概述(讲讲python基本语法和第三方库)
  • 形象地理解UE4中的数据结构 TLinkedListBase
  • 使用SSH建立内网穿透,能够访问内网的web服务器
  • GESP真题 | 2024年12月1级-编程题2《奇数和偶数》及答案(Python版)
  • 【RTD MCAL 篇3】 K312 MCU时钟系统配置
  • 微软自带日志输出+Serilog
  • vue学习——集成sass
  • Ubuntu22.04 gnome-builder gnome C 应用程序习练笔记(三)
  • ideal打包,如何访问项目根目录的libs中的jar包
  • C++力扣题目494--目标和 474--一和零
  • 突破编程_C++_基础教程(类的高级特性)
  • 勒索病毒是什么,如何预防?
  • 鸿蒙开发-UI-图形-图片
  • 鸿蒙(HarmonyOS)项目方舟框架(ArkUI)之Toggle组件
  • MySQL进阶查询篇(3)-查询性能优化的常见技巧
  • C#系列-C#操作UDP发送接收数据(10)
  • C++入门篇(4)—— 类与对象(1)
  • Spring Boot 实现热插拔 AOP
  • 【机器学习】Ubuntu系统下CUDA驱动卸载及重装
  • 上线GPT应用的流程
  • 【北邮鲁鹏老师计算机视觉课程笔记】03 edge 边缘检测
  • 深入浅出:Golang的Crypto/SHA256库实战指南
  • Linux第45步_通过搭建“DNS服务器”学习图形化配置工具
  • conda创建环境,查看环境,激活环境,查看包,复制环境,删除环境,查看cuda版本,查看pytorch版本
  • 蓝桥杯官网练习题(翻转)
  • ubuntu22.04@laptop OpenCV Get Started: 006_annotating_images