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

GESP6级C++考试语法知识(二十一、深度优先搜索(一、DFS 一条路走到黑))

第一课《迷宫探险队》——DFS 到底是什么一、故事开始勇敢的小骑士1、很久很久以前在算法王国里有一座神秘的迷宫城堡。2、城堡里面有墙壁有陷阱有死路还有一颗“黄金宝石”✨3、国王说“谁能找到宝石谁就是最聪明的小勇士”4、于是。小骑士 DFS 出发了二、小骑士是怎么找路的1、小骑士的方法非常简单✅ 能往前走就一直往前走2、如果前面是墙或者没路了3、那就✅ 退回来再换一条路继续试。4、这就是 DFSDFS 中文叫深度优先搜索什么意思5、“深度优先”是什么意思就是一条路先走到底例如A → B → C → D能继续走决不回头只有A → B → C → D ❌没路了才会退回 C然后看看还有没有别的路三、不要急着写代码我们先真正理解DFS 到底在干什么。1、迷宫地图我们有这样一个迷宫S . . # # # . # . . . E其中符号意思S起点E终点#墙.能走2、小骑士开始出发从 S 开始设定方向是向右走第一步S → .第二步继续走S → . → .第三步发现右边是墙#怎么办退回来于是← 回退再尝试别的方向。3、DFS 的核心动作其实只有两件事✅ 1. 往前搜✅ 2. 走不通就回来四、DFS 和栈有什么关系1、我们前面学过栈Stack栈的特点后进先出LIFO2、例如1压进去 2压进去 3压进去出来时3先出来 2再出来 1最后出来3、DFS 其实也一样例如A ↓ B ↓ C ↓ D现在 D 走不通了。会怎么退4、答案D回来 → C回来 → B回来是不是特别像栈5、所以DFS 本质 不断深入不断返回五、现在开始真正写 DFS1、任务判断是否能从 S 走到 E2、地图我们用0 能走 1 墙例如0 0 0 1 1 1 0 1 0 0 0 0终点是(2,3)六、 DFS 参考程序#include iostream using namespace std; int maze[10][10] { {0,0,0,1}, {1,1,0,1}, {0,0,0,0} }; bool vis[10][10]; int n 3; int m 4; bool found false; void dfs(int x,int y) { // 出界 if(x 0 || x n || y 0 || y m) return; // 墙 或 已经走过 if(maze[x][y] 1 || vis[x][y]) return; // 到达终点 if(x 2 y 3) { found true; return; } // 标记走过 vis[x][y] true; // 四个方向 dfs(x1,y); // 下 dfs(x-1,y); // 上 dfs(x,y1); // 右 dfs(x,y-1); // 左 } int main() { dfs(0,0); if(found) cout 能到终点; else cout 到不了终点; return 0; }七、理解代码不要背我们一步一步看。1. dfs(x,y)意思“从当前位置开始搜索”例如dfs(0,0)表示从左上角开始。2. 出界判断if(x 0 || x n || y 0 || y m) return;什么意思例如走到(-1,0)已经飞出地图了所以直接返回3. 墙壁判断if(maze[x][y] 1) return;说明撞墙了不能走4. visited 数组vis[x][y]表示“这里以前来过吗”为什么需要它否则会无限绕圈例如A ↔ B会变成A→B→A→B→A→B……程序永远停不下来5. 标记已经来过vis[x][y] true;意思“这里我来过啦”6. 四个方向搜索dfs(x1,y); dfs(x-1,y); dfs(x,y1); dfs(x,y-1);表示上下左右都试试看八、程序真正运行时是什么样开始dfs(0,0)接着往右dfs(0,1)再往右dfs(0,2)再往下dfs(1,2)最后dfs(2,3)找到终点九、DFS 最核心的一句话DFS 的本质当前点 ↓ 尝试下一步 ↓ 继续搜索 ↓ 走不通就返回十、本课总结今天学会了什么✅ 什么是 DFS一条路先走到底✅ DFS 的核心动作往前搜退回来✅ 为什么需要 vis防止死循环。✅ DFS 和栈的关系DFS 的返回过程像栈一样。✅ 我们的第一个 DFS 程序同学们已经会判断能否到终点二维 DFS四方向搜索十一、课后挑战请同学们挑战1修改地图自己设计迷宫。挑战2增加障碍物。看看还能不能到终点。挑战3把dfs顺序改掉。例如先左后右。观察搜索顺序有什么变化下节课预告下一节⚔️《递归魔法与搜索树》孩子会真正理解为什么 dfs() 能自己回来以及搜索树到底是什么

相关文章:

GESP6级C++考试语法知识(二十一、深度优先搜索(一、DFS 一条路走到黑))

第一课《迷宫探险队》——DFS 到底是什么?🌟一、故事开始:勇敢的小骑士1、很久很久以前,在算法王国里,有一座神秘的迷宫城堡。2、城堡里面:有墙壁有陷阱有死路还有一颗“黄金宝石”✨3、国王说:…...

手把手教你用FPGA+摄像头搭建一个图像处理系统(从采集到以太网传输)

从零构建FPGA图像处理系统:硬件选型到以太网传输实战指南 在嵌入式视觉领域,FPGA因其并行处理能力和低延迟特性,成为实时图像处理的理想平台。本文将带您完整实现一个基于OV7670摄像头和Xilinx Artix-7 FPGA的图像采集处理系统,涵…...

保姆级教程:用Wireshark抓包搞定Velodyne VLP-16激光雷达的IP配置与网络调试

从数据包到点云:Wireshark深度解析Velodyne VLP-16网络配置全流程 当你第一次拿到Velodyne VLP-16激光雷达时,那种兴奋感很快会被网络配置的挫败感取代——明明按照教程设置了IP,却始终ping不通设备,浏览器访问后台更是天方夜谭。…...

如何用一套键盘鼠标控制多台电脑:Input Leap跨平台KVM终极指南

如何用一套键盘鼠标控制多台电脑:Input Leap跨平台KVM终极指南 【免费下载链接】input-leap Open-source KVM software 项目地址: https://gitcode.com/gh_mirrors/in/input-leap 你是否厌倦了在办公桌上摆满多个键盘鼠标,每次切换设备都要重新调…...

终极音乐格式转换指南:3步完成音频解密与跨平台播放

终极音乐格式转换指南:3步完成音频解密与跨平台播放 【免费下载链接】unlock-music 在浏览器中解锁加密的音乐文件。原仓库: 1. https://github.com/unlock-music/unlock-music ;2. https://git.unlock-music.dev/um/web 项目地址: https:/…...

告别‘黑箱’聚合:深入解读GWCNet如何用组相关提升立体匹配效率与精度

告别‘黑箱’聚合:深入解读GWCNet如何用组相关提升立体匹配效率与精度 立体匹配一直是计算机视觉领域的核心挑战之一,尤其在自动驾驶、机器人导航等实时性要求高的场景中,如何在精度和效率之间找到平衡点成为算法设计的难点。传统方法往往陷入…...

别再死记硬背了!用这5个真实案例,彻底搞懂NumPy的einsum函数

别再死记硬背了!用这5个真实案例,彻底搞懂NumPy的einsum函数 当你第一次看到np.einsum(ij,jk->ik, A, B)这样的表达式时,是不是感觉像在破译外星密码?作为NumPy中最强大却也最令人困惑的函数之一,einsum&#xff08…...

高效实战:MicroPython ST7789显示屏驱动库深度解析

高效实战:MicroPython ST7789显示屏驱动库深度解析 【免费下载链接】st7789py_mpy Driver for 320x240, 240x240, 135x240 and 128x128 ST7789 displays written in MicroPython 项目地址: https://gitcode.com/gh_mirrors/st/st7789py_mpy ST7789显示屏驱动…...

LabVIEW生产者消费者模式:队列操作与多线程架构实战

1. 项目概述:从“单线程”到“流水线”的思维跃迁在LabVIEW的进阶之路上,生产者/消费者循环是一个绕不开的里程碑。很多朋友从基础的数据流编程走过来,习惯了顺序执行、平铺式的程序结构,一旦遇到需要同时处理多个任务、响应不同事…...

Anubis质检报告XTR文件:从数据字段到质量评估的实战解析

1. XTR文件基础:GNSS质检报告的核心载体 第一次拿到Anubis生成的XTR文件时,我盯着满屏的缩写和数据愣了半天。这种看似晦涩的文本文件,实际上是GNSS数据质量的"体检报告单"。就像医院的血常规化验单需要专业解读一样,XT…...

不用示波器也能调:在Vivado/Quartus里用时序约束搞定RGMII接口的建立保持时间

不依赖示波器的RGMII时序优化:FPGA工具链实战指南 当千兆以太网接口出现数据丢包或误码时,多数工程师的第一反应是抓起示波器测量信号完整性。但在实际项目周期中,硬件调试设备可能无法随时调用,而PCB设计又已成定局。此时&#x…...

BGP状态机详解:从邻居建立到故障排查的完整指南

1. 项目概述:从“拒绝一切”到“稳定对话”的BGP邻居建立之旅如果你在网络运维或者数据中心工作的岗位上待过一阵子,肯定对BGP(边界网关协议)又爱又恨。爱的是它作为互联网“大管家”的稳定和强大,恨的是它一旦出问题&…...

COLMAP稠密点云太稀疏?OpenMVS点云又太密?试试这个‘黄金搭档’配置方案

COLMAP与OpenMVS混合重建:如何实现点云密度与计算效率的黄金平衡 在三维重建领域,我们常常面临一个两难选择:COLMAP生成的稠密点云往往过于稀疏,导致最终网格模型细节不足;而OpenMVS自带的稠密重建又容易产生过度密集的…...

二层与三层交换机核心差异解析:从MAC地址到IP路由的实战指南

1. 项目概述:从“傻”到“聪明”的进化之路如果你刚接触网络设备,看到“二层交换机”和“三层交换机”这两个名词,可能会有点懵。它们长得都差不多,都是方方正正的铁盒子,前面板一堆网口,后面插着电源和风扇…...

炸了!Claude 更新后 Mac 老系统直接报废:开发者凌晨三点爬起来修环境

一、真实事故现场:上海某团队的惊魂一夜 2026年5月15日凌晨2:37,上海浦东某科技公司。 高级工程师小李盯着屏幕上的错误信息,手指在键盘上飞快地敲击着。他面前是三个显示器,每个都显示着不同的终端窗口,满屏的红色错误信息像血一样刺眼。 "这怎么可能?"他自…...

agent 学习路径解析 学习资源分享

文章目录 先给结论:你接下来不要优先读 GLM-4.5你对 agent 的轻视,有一半对,一半错关于 Claude Code 泄露:你应该学“架构收获”,不要沉迷“源码猎奇”你提到的 learn-claude-code 仓库:值得看,…...

突破95%准确率:中文BERT-wwm情感分析深度实战指南

突破95%准确率:中文BERT-wwm情感分析深度实战指南 【免费下载链接】Chinese-BERT-wwm Pre-Training with Whole Word Masking for Chinese BERT(中文BERT-wwm系列模型) 项目地址: https://gitcode.com/gh_mirrors/ch/Chinese-BERT-wwm …...

5步掌握BG3SE:让《博德之门3》成为你的创意画布

5步掌握BG3SE:让《博德之门3》成为你的创意画布 【免费下载链接】bg3se Baldurs Gate 3 Script Extender 项目地址: https://gitcode.com/gh_mirrors/bg/bg3se BG3SE(博德之门3脚本扩展器) 是一款革命性的开源工具,它通过L…...

告别键盘鼠标切换烦恼:开源KVM软件Input Leap让你一套键鼠控制多台电脑

告别键盘鼠标切换烦恼:开源KVM软件Input Leap让你一套键鼠控制多台电脑 【免费下载链接】input-leap Open-source KVM software 项目地址: https://gitcode.com/gh_mirrors/in/input-leap 你是否经常在Windows、macOS和Linux多台电脑之间来回切换&#xff0c…...

用STM32F401的I2S接口驱动TM8211 DAC播放WAV音频,保姆级CubeMX配置教程

基于STM32F401的TM8211音频播放系统开发指南 1. 硬件系统搭建与原理分析 在开始CubeMX配置之前,我们需要先理解整个音频播放系统的硬件架构和工作原理。STM32F401通过I2S接口与TM8211 DAC芯片通信,将数字音频信号转换为模拟信号,最终驱动扬…...

MarkdownViewer++:5分钟让Notepad++变身专业Markdown编辑器的终极指南

MarkdownViewer:5分钟让Notepad变身专业Markdown编辑器的终极指南 【免费下载链接】MarkdownViewerPlusPlus A Notepad Plugin to view a Markdown file rendered on-the-fly 项目地址: https://gitcode.com/gh_mirrors/ma/MarkdownViewerPlusPlus 你是否还在…...

国产MCU生态构建与MM32系列选型开发实战解析

1. 项目概述:一场MCU生态的“集结号”2018年的那个秋天,对于国内嵌入式开发者,尤其是那些常年与ARM Cortex-M内核打交道的工程师们来说,记忆里应该有一场绕不开的盛会——灵动微电子举办的“2018灵动MM32协作大会”。这场大会的核…...

无人机载RIS混合能量收集系统设计与优化

1. 无人机载RIS混合能量收集系统概述 在6G物联网通信场景中,无人机搭载可重构智能表面(RIS)的技术组合正在重塑无线网络架构。这种创新方案通过将RIS的被动波束赋形能力与无人机的三维机动性相结合,有效解决了传统地面基站覆盖范围有限、部署不灵活的痛点…...

挤馅机性价比选择:企业采购决策关键因素深度解析

挤馅机性价比选择:企业采购决策关键因素深度解析“选挤馅机只看价格?错!挤馅机性价比的核心是‘长期使用成本’而非‘单次采购价’”企业采购挤馅机时,常陷入“价格越低越划算”的误区,却忽略了后期维护、产能波动等隐…...

你还在手动查证引文和逻辑漏洞?Perplexity书评辅助的实时溯源与反事实验证机制(仅限Pro+插件开放)

更多请点击: https://codechina.net 第一章:你还在手动查证引文和逻辑漏洞?Perplexity书评辅助的实时溯源与反事实验证机制(仅限Pro插件开放) Perplexity Pro 插件引入的实时溯源与反事实验证机制,彻底重构…...

计算机科学论文降AI工具免费推荐:2026年计算机毕业论文知网维普降AI4.8元亲测完整方案

计算机科学论文降AI工具免费推荐:2026年计算机毕业论文知网维普降AI4.8元亲测完整方案 答辩前夕,AI率36%,学校要求15%以下。 用嘎嘎降AI(www.aigcleaner.com),4.8元,两小时搞定,一…...

别再只烧SD卡了!IMX6ULL的BOOT_CFG引脚配置详解(附正点原子核心板电路图)

IMX6ULL启动配置全解析:从BOOT_CFG引脚到多介质启动实战 当你在深夜调试IMX6ULL开发板时,是否遇到过这样的困境——明明按照教程操作,系统却始终无法从EMMC启动?问题的根源往往藏在那些容易被忽略的硬件细节中。今天,我…...

【技术解析】目标导向语义探索:如何让机器人学会“按图索骥”

1. 当机器人学会"按图索骥" 想象一下,你被蒙着眼睛带进一个陌生的家具商场,任务是找到一张红色沙发。正常人会先摸到墙壁确定方位,听到脚步声判断通道方向,闻到咖啡香推测休息区位置——这种多模态信息整合能力&#x…...

如何用AI智能分层技术将单张插画转化为可编辑的PSD文件

如何用AI智能分层技术将单张插画转化为可编辑的PSD文件 【免费下载链接】layerdivider A tool to divide a single illustration into a layered structure. 项目地址: https://gitcode.com/gh_mirrors/la/layerdivider 你是否曾经面对一张精美的插画,想要对…...

终极LevelDB GUI管理工具:LevelUI完整使用指南

终极LevelDB GUI管理工具:LevelUI完整使用指南 【免费下载链接】levelui A GUI for LevelDB management based on atom-shell. 项目地址: https://gitcode.com/gh_mirrors/le/levelui LevelDB作为高性能键值存储数据库,在Node.js生态中应用广泛&a…...