news 2026/4/23 12:24:30

【计算机算法与设计(14)】例题五:最小生成树:Prim算法详细解释:π的含义、更新逻辑和选点原因

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【计算机算法与设计(14)】例题五:最小生成树:Prim算法详细解释:π的含义、更新逻辑和选点原因

文章目录

    • 📋 题目
    • 🔑 一、理解关键概念
      • 1.1 d(v) 是什么?
      • 1.2 π(v) 是什么?
    • 📊 二、新的例题
    • 🎯 三、关键问题解答
      • Q1:d(V)更新的逻辑是什么?
      • Q2:为什么选择某个点?
      • Q4:π值什么时候改变?
    • 📝 四、总结
      • 核心概念
      • 算法流程
      • 关键理解

📋 题目




🔑 一、理解关键概念

1.1 d(v) 是什么?

d(v) 的含义

  • 当前已知的,从顶点v到已连通区域最短距离
  • 如果v已经在连通区域中,d(v) = 0
  • 如果v还没连通,d(v) = 从v到连通区域的某条边的最小权重

通俗理解

  • 就像"从村庄v到已修路区域,最便宜的路要花多少钱"
  • 初始时,除了起始点,其他点的d值都是∞(无穷大)

1.2 π(v) 是什么?

π(v) 的含义

  • 父节点:在已连通区域中,哪个顶点通过权重为d(v)的边连接到v
  • 如果v已经在连通区域中,π(v) = nil(没有父节点,或者是起始点)

通俗理解

  • 就像"从哪个村庄修路到v最便宜"
  • 如果d(v) = 4, π(v) = a,意思是"从a修路到v,成本是4"

关键关系

  • 边 (π(v), v) 的权重 = d(v)
  • 这条边就是"当前已知的,连接v到连通区域的最便宜的路"

📊 二、新的例题


🎯 三、关键问题解答

Q1:d(V)更新的逻辑是什么?

更新规则

对于新加入连通区域的顶点u,检查它的每个邻居v:

如果 v 还没连通(v不在连通区域中): 如果 w(u,v) < d(v): 更新:d(v) = w(u,v) 更新:π(v) = u

通俗理解

  • “如果从u到v的路,比v当前已知的最便宜的路更便宜”
  • “就更新v的距离和父节点”

例子:步骤©中更新d

  • 选择e后,检查e → d
  • d当前:d(d) = 5(从a到d)
  • e → d:权重4
  • 因为4 < 5,所以更新:d(d) = 4,π(d) = e

Q2:为什么选择某个点?

选择规则:从所有未连通的顶点中,选择d值最小的

为什么这样选择?

贪心思想

  • d值最小 = 连接到连通区域最便宜
  • 每次选择最便宜的,保证总成本最小

证明思路(简化):

  • 假设存在更优的方案,不选择d值最小的点
  • 那么必然存在一条更便宜的路
  • 但我们选择的是d值最小的,矛盾!
  • 所以选择d值最小的是最优的

例子:步骤(c)中选择e

  • 未连通顶点:{b, c, d, e, f}
  • d值:b=4, c=∞, d=5, e=2, f=6
  • e的d值最小(2),所以选择e

Q4:π值什么时候改变?

π值改变的条件

  1. 初始时:所有顶点的π = nil
  2. 第一次发现路径:当某个顶点v第一次被发现可以连接到连通区域时
    • 例如:步骤(b)中,b第一次被发现,π(b) = a
  3. 发现更便宜的路径:当发现从新顶点u到v的路,比v当前已知的路更便宜时
    • 例如:步骤©中,发现e → d(4)比a → d(5)便宜,所以π(d)从a改为e

π值不变的情况

  • 如果新发现的路径不比当前已知的路径便宜,π值不变
  • 例如:步骤©中,e → f(9)不比a → f(6)便宜,所以π(f)保持为a

📝 四、总结

核心概念

  1. d(v):从v到连通区域的最短距离(当前已知的)
  2. π(v):v的父节点,通过权重为d(v)的边连接到v
  3. 选择规则:每次选择d值最小的未连通顶点
  4. 更新规则:如果发现更便宜的路径,更新d和π值

算法流程

1. 初始化:选择起始点a,d(a)=0,其他d(v)=∞ 2. 重复直到所有顶点连通: a. 选择d值最小的未连通顶点u b. 把u加入连通区域,修路(π(u), u) c. 更新u的邻居:如果发现更便宜的路径,更新d和π 3. 返回MST

关键理解

  • 贪心策略:每次选择最便宜的,得到全局最优
  • 动态更新:随着连通区域扩大,不断发现更便宜的路径
  • π值记录最优路径:π(v)记录"当前已知的,连接v到连通区域的最便宜的方式"

💡记忆要点:d值记录距离,π值记录父节点,选择最小d值,更新更便宜路径!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 12:33:47

阿里云盘Refresh Token获取指南:三步搞定扫码工具

还在为复杂的API授权流程头疼吗&#xff1f;想快速获取阿里云盘Refresh Token却不知道从何下手&#xff1f;这款开源扫码工具让你用最简单的方式搞定一切&#xff01;无需技术背景&#xff0c;只需三步操作&#xff0c;就能轻松获取阿里云盘Refresh Token&#xff0c;实现云盘自…

作者头像 李华
网站建设 2026/4/16 8:42:00

12、Unix 文件处理实用工具全解析

Unix 文件处理实用工具全解析 在 Unix 系统中,有许多实用工具可用于文件比较、排序、去重、格式转换等操作。这些工具能帮助用户高效地处理文件,提高工作效率。下面将详细介绍这些实用工具的使用方法和技巧。 1. 使用 cmp 比较文件 cmp 命令用于比较两个文件,找出它们…

作者头像 李华
网站建设 2026/4/15 13:12:29

16、Unix 环境配置:bash、ksh 和 csh 详细指南

Unix 环境配置:bash、ksh 和 csh 详细指南 1. 更改 bash 提示符 在 Unix 系统中,默认的 bash 提示符可能只是一个美元符号($),或者是美元符号和日期等信息。你可以根据自己的需求自定义提示符,以包含对自己有用的信息。 1.1 bash 提示符类型 bash 中有两种提示符: …

作者头像 李华
网站建设 2026/4/3 12:25:11

17、Unix 系统命令别名设置与作业管理全解析

Unix 系统命令别名设置与作业管理全解析 在 Unix 系统的使用过程中,为了提高操作的便捷性和效率,我们可以使用命令别名(Aliases),还能对作业进行灵活的管理,包括运行、调度、暂停、检查状态等操作。下面将详细介绍这些功能的使用方法。 命令别名(Aliases)设置 命令别…

作者头像 李华
网站建设 2026/4/22 16:55:15

21、Unix 系统下的邮件操作指南

Unix 系统下的邮件操作指南 在 Unix 系统中,有多种工具可用于处理邮件,如 pine、mutt 和 mail 等。下面将详细介绍这些工具的使用方法,包括自定义设置、阅读和发送邮件等操作,同时还会涉及创建签名文件、自动转发邮件以及设置假期自动回复等内容。 1. 自定义 pine pine …

作者头像 李华
网站建设 2026/4/22 3:47:09

突破上下文壁垒:Qwen3-Next-80B-A3B-Instruct引领大模型超长文本处理新纪元

在大语言模型技术日新月异的今天&#xff0c;上下文窗口长度与推理效率的平衡始终是行业痛点。Qwen3-Next-80B-A3B-Instruct作为新一代旗舰级指令微调模型&#xff0c;凭借256K tokens的超长上下文支持、创新混合注意力机制及高稀疏性专家系统&#xff0c;正在重新定义大模型的…

作者头像 李华