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

别再死记硬背DFS了!用邻接矩阵图解深度优先遍历的每一步(C语言实例)

邻接矩阵DFS可视化用二维表格拆解深度优先遍历全过程邻接矩阵是图论中最直观的存储结构之一但很多学习者在理解DFS递归过程时仍感到抽象。本文将用邻接矩阵的二维表格形式动态图解DFS算法的每一步状态变化让你真正看见递归如何探索图的每个角落。1. 邻接矩阵与DFS的核心交互机制邻接矩阵用一个二维数组G[N][N]表示图中顶点间的连接关系。假设我们有一个包含5个顶点的无向图其邻接矩阵可能如下所示01234001010110100201011310100400100DFS在这个矩阵上的操作可以分解为三个关键动作访问顶点V执行Visit(V)操作标记已访问设置Visited[V] true查找邻接点按顺序检查G[V][0]到G[V][N-1]对未访问的邻接点递归调用DFSvoid DFS(MGraph Graph, Vertex V, void (*Visit)(Vertex)) { Visited[V] true; // 标记当前顶点已访问 Visit(V); // 执行访问操作 // 按顺序检查所有可能的邻接点 for (Vertex i 0; i Graph-Nv; i) { if (Graph-G[V][i] 1 !Visited[i]) { DFS(Graph, i, Visit); // 递归访问未探索的邻接点 } } }2. 可视化递归过程从矩阵视角看DFS让我们以从顶点0开始的DFS为例逐步展示邻接矩阵和访问状态的变化。初始状态访问标记数组[false, false, false, false, false]访问顺序空步骤1访问顶点0标记Visited[0] true访问顺序0检查邻接点G[0][1]1且Visited[1]false → 递归DFS(1)步骤2在DFS(1)中标记Visited[1] true访问顺序0 1检查邻接点G[1][0]1但Visited[0]true → 跳过G[1][2]1且Visited[2]false → 递归DFS(2)步骤3在DFS(2)中标记Visited[2] true访问顺序0 1 2检查邻接点G[2][1]1但Visited[1]true → 跳过G[2][3]1且Visited[3]false → 递归DFS(3)我们可以用下面的表格记录每一步的访问状态递归深度当前顶点访问顺序访问标记数组100[T,F,F,F,F]210 1[T,T,F,F,F]320 1 2[T,T,T,F,F]430 1 2 3[T,T,T,T,F]32--440 1 2 3 4[T,T,T,T,T]3. 非连通图的遍历策略上述代码在连通图中工作良好但对于非连通图会遗漏未连接的组件。改进方法是在主函数中对所有顶点启动DFSint main() { MGraph G; Vertex V; G CreateGraph(); // 对每个未访问的顶点启动DFS for (Vertex i 0; i G-Nv; i) { if (!Visited[i]) { printf(DFS from %d:, i); DFS(G, i, Visit); printf(\n); } } return 0; }考虑下面的非连通图邻接矩阵01234001000110000200010300100400000遍历过程将分为三个部分从顶点0开始访问顺序0 1从顶点2开始访问顺序2 3从顶点4开始访问顺序44. 调试技巧打印递归轨迹为了更好地理解DFS的执行流程可以在递归函数中添加调试输出void DFS(MGraph Graph, Vertex V, void (*Visit)(Vertex)) { printf(Entering DFS for vertex %d\n, V); Visited[V] true; Visit(V); for (Vertex i 0; i Graph-Nv; i) { if (Graph-G[V][i] 1) { printf(Checking edge %d-%d (visited%d)\n, V, i, Visited[i]); if (!Visited[i]) { DFS(Graph, i, Visit); } } } printf(Exiting DFS for vertex %d\n, V); }对于前面的连通图示例输出可能如下Entering DFS for vertex 0 Visiting 0 Checking edge 0-1 (visited0) Entering DFS for vertex 1 Visiting 1 Checking edge 1-0 (visited1) Checking edge 1-2 (visited0) Entering DFS for vertex 2 Visiting 2 Checking edge 2-1 (visited1) Checking edge 2-3 (visited0) Entering DFS for vertex 3 Visiting 3 Checking edge 3-0 (visited1) Checking edge 3-2 (visited1) Exiting DFS for vertex 3 Checking edge 2-4 (visited0) Entering DFS for vertex 4 Visiting 4 Checking edge 4-2 (visited1) Exiting DFS for vertex 4 Exiting DFS for vertex 2 Exiting DFS for vertex 1 Exiting DFS for vertex 0这种调试方法清晰地展示了递归的进入和退出顺序以及每次递归调用时的上下文状态。

相关文章:

别再死记硬背DFS了!用邻接矩阵图解深度优先遍历的每一步(C语言实例)

邻接矩阵DFS可视化:用二维表格拆解深度优先遍历全过程 邻接矩阵是图论中最直观的存储结构之一,但很多学习者在理解DFS递归过程时仍感到抽象。本文将用邻接矩阵的二维表格形式,动态图解DFS算法的每一步状态变化,让你真正"看见…...

别再只盯着最大池化了!PyTorch实战:用nn.AvgPool2d给图像分类任务‘降噪’与‘瘦身’

别再只盯着最大池化了!PyTorch实战:用nn.AvgPool2d给图像分类任务‘降噪’与‘瘦身’ 当你在构建第一个卷积神经网络时,是否也曾经像我一样,习惯性地在所有下采样层都使用最大池化(Max Pooling)&#xff1f…...

医用手套缺陷检测系统

守护医疗防线:医用手套缺陷检测平台全解析医用手套作为医疗场景中第一道安全屏障,其质量直接关系到医护人员与患者的生命健康。传统人工检测效率低、误差大,难以满足规模化生产的高标准需求。医用手套缺陷检测平台凭借AI视觉、自动化技术&…...

别再瞎调饱和度了!高通平台Camera色彩校正(CC)保姆级调试指南(附避坑清单)

高通平台Camera色彩校正实战:从数据驱动到精准调校的完整方法论 当一张照片呈现出的色彩让你忍不住皱眉时,多数人的第一反应是"饱和度不够"——这种直觉式的判断往往让Camera Tuning工程师陷入反复试错的泥潭。在专业影像调试领域,…...

魔兽争霸III兼容性修复工具:WarcraftHelper让经典游戏在Windows 11完美运行

魔兽争霸III兼容性修复工具:WarcraftHelper让经典游戏在Windows 11完美运行 【免费下载链接】WarcraftHelper Warcraft III Helper , support 1.20e, 1.24e, 1.26a, 1.27a, 1.27b 项目地址: https://gitcode.com/gh_mirrors/wa/WarcraftHelper 还在为魔兽争霸…...

3分钟掌握Obsidian加密插件:保护你的数字隐私笔记

3分钟掌握Obsidian加密插件:保护你的数字隐私笔记 【免费下载链接】obsidian-encrypt Hide secrets in your Obsidian.md vault 项目地址: https://gitcode.com/gh_mirrors/ob/obsidian-encrypt 在数字时代,我们的笔记中常常包含敏感信息&#xf…...

从数据丢失到稳定传输:我是如何用硬件流控拯救蓝牙文件传输项目的

蓝牙大文件传输的稳定性救星:硬件流控实战解析 蓝牙技术早已从简单的音频传输扩展到各类工业与消费级应用场景,但当我们尝试通过蓝牙传输大容量文件——比如高清图片、固件升级包或批量传感器数据时,许多开发者都会遇到一个令人头疼的问题&am…...

OpenModScan:让Modbus调试变得像聊天一样简单

OpenModScan:让Modbus调试变得像聊天一样简单 【免费下载链接】OpenModScan Open ModScan is a Free Modbus Master (Client) Utility 项目地址: https://gitcode.com/gh_mirrors/op/OpenModScan 如果你在工业自动化领域工作,一定对Modbus协议不陌…...

SAP Fiori Launchpad 的三种形态

很多朋友一看到 SAP Fiori Launchpad,就会把它理解成一个带磁贴的首页。 这样理解当然没有什么错误。 但如果多做几个 Fiori 项目之后,就会发现 Fiori Launchpad 背后还是有点东西的。 它更像一个统一壳层,负责把 SAP 用不同技术栈写出来的应用装进同一套入口(Shell)里,…...

每日一书⑯ | 穷查理宝典:为什么聪明人总是做蠢事?多元思维模型的力量

“本文来自「乐想屋」公众号,系列更新[每日一书],每次5分钟,帮你把书读薄,把知识用活”01 开篇:那些矛盾的瞬间学历很高,但投资决策一塌糊涂在某个领域是专家,但在其他领域幼稚得可笑拿着锤子看…...

为什么这款轻量级图像查看器JPEGView能让你告别臃肿软件?[特殊字符]

为什么这款轻量级图像查看器JPEGView能让你告别臃肿软件?🚀 【免费下载链接】jpegview Fork of JPEGView by David Kleiner - fast and highly configurable viewer/editor for JPEG, BMP, PNG, WEBP, TGA, GIF and TIFF images with a minimal GUI. Bas…...

TSC技术:晶闸管投切电容器实现无功补偿与静止无功补偿器的应用

TSC,晶闸管投切电容器,无功补偿,静止无功补偿器,车间里的日光灯突然暗了下来,操作工老张骂骂咧咧地拍打着配电箱。这是十年前我在钢厂实习时常见的场景,电压波动像顽疾般困扰着生产线。直到我接触到TSC&…...

2026奇点大会AI设计助手技术白皮书深度拆解(仅限首批参会者泄露版)

第一章:2026奇点智能技术大会:AI设计助手 2026奇点智能技术大会(https://ml-summit.org) 核心能力演进 本届大会发布的AI设计助手v3.2突破传统UI生成边界,首次实现跨模态设计意图理解——支持语音草图、手绘线稿、自然语言描述三路输入统一…...

Mac NTFS读写终极指南:免费开源工具Nigate完整教程

Mac NTFS读写终极指南:免费开源工具Nigate完整教程 【免费下载链接】Free-NTFS-for-Mac Nigate: An open-source NTFS utility for Mac. It supports all Mac models (Intel and Apple Silicon), providing full read-write access, mounting, and management for N…...

三电平NPC逆变器矢量控制(SVPWM)算法解析与调制波形探究

三电平NPC逆变器矢量控制(SVPWM)matlab2021a 采用矢量控制,大扇区、小扇区、矢量作用时间等均用程序编写,可以得到马鞍波调制波形 逆变器输出三电平相电压波形,五电平线电压波形, 经过滤波器后,…...

终极指南:如何用DeepEval构建全流程可控的LLM评测系统

终极指南:如何用DeepEval构建全流程可控的LLM评测系统 【免费下载链接】deepeval The LLM Evaluation Framework 项目地址: https://gitcode.com/GitHub_Trending/de/deepeval 还在为LLM(大语言模型)的评测质量发愁吗?担心…...

工业物联网设备通讯难题?OpenModScan提供专业Modbus测试解决方案

工业物联网设备通讯难题?OpenModScan提供专业Modbus测试解决方案 【免费下载链接】OpenModScan Open ModScan is a Free Modbus Master (Client) Utility 项目地址: https://gitcode.com/gh_mirrors/op/OpenModScan OpenModScan是一款功能强大的免费开源Modb…...

DataX批量导入多张表的自动化实践:从JSON模板到Shell脚本

1. 为什么需要批量导入多张表? 在实际的数据迁移或ETL项目中,经常会遇到需要同时处理多张表的情况。比如最近我接手的一个项目,需要将客户的老系统数据迁移到新平台,涉及的表多达50多张。如果按照传统方式,为每张表单独…...

Fashion MNIST分类任务中的常见陷阱与优化技巧:从90%到91%的实战经验

Fashion MNIST分类任务中的常见陷阱与优化技巧:从90%到91%的实战经验 当你在Fashion MNIST数据集上训练一个分类模型时,90%的准确率似乎是个不错的起点。但当你发现无论如何调整参数,模型性能始终徘徊在这个水平时,那种挫败感只有…...

如何快速解锁加密音乐文件:Unlock-Music完整免费指南

如何快速解锁加密音乐文件:Unlock-Music完整免费指南 【免费下载链接】unlock-music 在浏览器中解锁加密的音乐文件。原仓库: 1. https://github.com/unlock-music/unlock-music ;2. https://git.unlock-music.dev/um/web 项目地址: https:…...

如何永久保存微信聊天记录?这款开源工具让你完全掌控个人数字记忆

如何永久保存微信聊天记录?这款开源工具让你完全掌控个人数字记忆 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trendi…...

多模态大模型自动化运维方案(企业级POC验证白皮书):覆盖日志/指标/拓扑/工单/视频巡检5维感知

第一章:多模态大模型自动化运维方案概述 2026奇点智能技术大会(https://ml-summit.org) 多模态大模型自动化运维(M3-Ops)是面向AIGC基础设施、智能算力集群与异构AI工作负载的一体化智能治理范式。它融合视觉、文本、时序日志、拓扑图谱与系…...

AI时代Geo优化:官网标签如何铸就信任与流量新高

概述 在人工智能(AI)日益主导信息获取的今天,传统的搜索引擎优化(SEO)正经历一场深刻的变革,逐步演进为生成式引擎优化(Generative Engine Optimization, GEO)。GEO不再仅仅是追求关…...

【国家级AI治理实验室内部方法论】:基于172万图文对+43万音频样本验证的偏见动态监测系统(含GitHub可运行Pipeline)

第一章:多模态大模型偏见检测与消除 2026奇点智能技术大会(https://ml-summit.org) 多模态大模型在图像-文本对齐、跨模态推理等任务中展现出强大能力,但其训练数据固有的社会性偏差常被放大并编码为隐式决策偏好,导致性别刻板印象、种族关联…...

如何在5分钟内为视频添加AI字幕?AutoSubs完整指南揭秘

如何在5分钟内为视频添加AI字幕?AutoSubs完整指南揭秘 【免费下载链接】auto-subs Instantly generate AI-powered subtitles on your device. Works standalone or connects to DaVinci Resolve. 项目地址: https://gitcode.com/gh_mirrors/au/auto-subs 还…...

LVGL v9基础对象(lv_obj)实战:从HTML的div到嵌入式UI的布局核心

LVGL v9基础对象(lv_obj)实战&#xff1a;从HTML的div到嵌入式UI的布局核心 在嵌入式UI开发中&#xff0c;LVGL的基础对象lv_obj如同Web开发中的<div>元素&#xff0c;是构建复杂界面的基石。本文将深入探讨如何利用lv_obj实现类似HTML的布局系统&#xff0c;并通过实战案…...

智能网络边界守护者:OpenWrt访问控制插件深度实践指南

智能网络边界守护者&#xff1a;OpenWrt访问控制插件深度实践指南 【免费下载链接】luci-access-control OpenWrt internet access scheduler 项目地址: https://gitcode.com/gh_mirrors/lu/luci-access-control 在万物互联的时代&#xff0c;家庭网络已不再是简单的上网…...

企业自建防护 vs 第三方高防服务:怎么选才不花冤枉钱?一篇讲透性价比

企业自建防护与第三方高防服务对比成本投入自建防护&#xff1a;需采购硬件设备&#xff08;如防火墙、负载均衡器&#xff09;、软件授权及运维团队&#xff0c;前期投入高&#xff0c;适合长期需求稳定且预算充足的企业。硬件成本可能达数十万至百万级&#xff0c;且需持续支…...

从失败到成功:泰山派Debian镜像制作全记录(含鲁班猫仓库改造技巧)

泰山派Debian镜像制作实战&#xff1a;从官方文档失败到鲁班猫仓库改造的完整指南 当我在深夜第三次尝试按照泰山派官方文档构建Debian镜像时&#xff0c;终端上红色的报错信息格外刺眼。作为嵌入式开发者&#xff0c;我们常常需要为特定开发板定制操作系统镜像&#xff0c;而…...

20张图的保姆级教程,记录使用Verdaccio在Ubuntu服务器上搭建Npm私服

在技术领域&#xff0c;我们常常被那些闪耀的、可见的成果所吸引。今天&#xff0c;这个焦点无疑是大语言模型技术。它们的流畅对话、惊人的创造力&#xff0c;让我们得以一窥未来的轮廓。然而&#xff0c;作为在企业一线构建、部署和维护复杂系统的实践者&#xff0c;我们深知…...