【期末复习】例题说明Prim算法与Kruskal算法
点睛
Prim与Kruskal算法是用来求图的最小生成树的算法。最小生成树有n个顶点,n-1条边,不能有回路。
Prim算法
Prim算法的特点是从个体到整体,随机选定一个顶点为起始点出发,然后找它的权值最小的边对应的另一个顶点,这两个顶点就构成了新的个体(连通图),然后在这两个顶点的所有边中找权值最小的边对应的另一个顶点(前提是加进来不能导致已有的顶点所在的连通图构成回路),就这样直到所有顶点都并入同一个连通图,算法结束。
例1利用Prim算法求下图的一棵最小生成树,设顶点1为起始点,写出求解过程。

答案:
找到顶点1权值最小的边(1,3),则顶点1和3构成新的连通图
找到顶点1和3中权值最小的边(3,4),则顶点1,3,4构成新的连通图
找到顶点1,3,4中权值最小的边(4,7),则顶点1,3,4,7构成新的连通图
找到顶点1,3,4,7中权值最小的边(7,8),则顶点1,3,4,7,8构成新的连通图
找到顶点1,3,4,7,8中权值最小的边(8,6),则顶点1,3,4,7,8,6构成新的连通图
找到顶点1,3,4,7,8中权值最小的边(8,5),则顶点1,3,4,7,8,6,5构成新的连通图
找到顶点1,3,4,7,8,5中权值最小的边(1,2),则顶点1,3,4,7,8,6,5,2构成新的连通图
至此Prim算法结束,找到最小生成树如下图

Kruskal算法
Kruskal算法的特点是从整体到个体,它把整个图(默认是无向连通图)看做n个独立的顶点,然后把图的所有带权边根据权值大小升序排列存入一个序列中。最后依次从序列中取出这些边加入n个独立的顶点使它们成为同一个连通图的一部分,只要取出的边的数量不到n-1就一直取。在取的过程中如果有一条边的加入会造成回路,则跳过选下一个权值稍大的边。
例2利用Kruskal算法求下图的一棵最小生成树,写出求解过程。

答案:
将图中所有的边按照权值大小升序排列存入集合中,结果如下:
{(1,2), (1,3), (1,4), (2,5), (2,6), (3,4, (3,7), (4, 5), (4,7), (5,6), (5, 8), (6,8), (7,8)}
从集合中取出边(1,2),顶点1和2构成一个新的连通图
从集合中取出边(1,3),顶点1,2,3构成一个新的连通图
从集合中取出边(1,4),顶点1,2,3,4构成一个新的连通图
从集合中取出边(2,5),顶点1,2,3,4,5构成一个新的连通图
从集合中取出边(2,6),顶点1,2,3,4,5,6构成一个新的连通图
从集合中取出边(3,4),会在顶点1,3,4之间构成回路跳过
从集合中取出边(3,7),顶点1,2,3,4,5,6,7构成一个新的连通图
从集合中取出边(4,5),会在顶点1,2,4,5构成回路,跳过
从集合中取出边(4,7),顶点1,3,4,7构成回路,跳过
从集合中取出边(5,6),顶点2,5,6构成回路,跳过
从集合中取出边(5,8),顶点1,2,3,4,5,6,7,8构成一个新的连通图
边的个数达到n-1,结束,最小生成树如下图:

相关文章:
【期末复习】例题说明Prim算法与Kruskal算法
点睛Prim与Kruskal算法是用来求图的最小生成树的算法。最小生成树有n个顶点,n-1条边,不能有回路。Prim算法Prim算法的特点是从个体到整体,随机选定一个顶点为起始点出发,然后找它的权值最小的边对应的另一个顶点,这两个…...
AtCoder Beginner Contest 290 A-E F只会n^2
ABC比较简单就不再复述 D - Marking 简要题意 :给你一个长度为nnn的数组,下标为0到n−10 到 n-10到n−1,最初指针位于0,重复执行n-1次操作,每次操作的定义为将当前指针加上ddd,如果该位置为空(未填数),否则我们向右找到第一个为空…...
springMvc源码解析
入口:找到springboot的自动配置,将DispatcherServlet和DispatcherServletRegistrationBean注入spring容器(DispatcherServletRegistrationBean间接实现了ServletContextInitializer接口,最终ServletContextInitializer的onStartup…...
采用aar方式将react-native集成到已有安卓APP
关于react-native和android的开发环境搭建、环境变量配置等可以查看官方文档。 官方文档地址 文章中涉及的node、react等版本: node:v16.18.1 react:^18.1.0 react-native:^0.70.6 gradle:gradle-7.2开发工具:VSCode和android studio 关于react-native和…...
Tomcat目录介绍,结构目录有哪些?哪些常用?
bin 启动,关闭和其他脚本。这些 .sh文件(对于Unix系统)是这些.bat文件的功能副本(对于Windows系统)。由于Win32命令行缺少某些功能,因此此处包含一些其他文件。 比如说:windows下启动tomcat用的…...
Elasticsearch也能“分库分表“,rollover实现自动分索引
一、自动创建新索引的方法 MySQL的分库分表大家是非常熟悉的,在Elasticserach中有存在类似的场景需求。为了不让单个索引太过于庞大,从而引发性能变差等问题,我们常常有根据索引大小、时间等创建新索引的需求,解决方案一般有两个…...
6 大经典机器学习数据集,3w+ 用户票选得出,建议收藏
内容一览:本期汇总了超神经下载排名众多的 6 个数据集,涵盖图像识别、机器翻译、遥感影像等领域。这些数据集质量高、数据量大,经历人气认证值得收藏码住。 关键词:数据集 机器翻译 机器视觉 数据集是机器学习模型训练的基础&…...
Logview下载
Logview下载 之前一直用的NotePad 后来偶尔的看到作者有发布不当言论 就卸载了又去下载了NotePad– 但是,其实不管是 还是 – 打开大一些的文件都会卡死 所以就搜了这个logview 用起来还不错,目前我这再大的文件 这个软件都是秒打开 但是也会有一点点小…...
macos 下载 macOS 系统安装程序及安装U盘制作方法
01 下载 macOS 系统安装程序的方法 本文来自: https://discussionschinese.apple.com/docs/DOC-250004259 简介 Mac 用户时不时会需要下载 macOS 的安装程序,目的不同,或者升级或者降级,或者研究或者收藏。为了方便不同用户,除…...
c++动态内存分布以及和C语言的比较
文章目录 前言一.c/c内存分布 C语言的动态内存管理方式 C内存管理方式 operator new和operator delete函数 malloc/free和new/delete的区别 定位new 内存泄漏的危害总结前言 c是在c的基础上开发出来的,所以关于内存管理这一方面是兼容c的&…...
软考高级信息系统项目管理师系列之三十一:项目变更管理
软考高级信息系统项目管理师系列之三十一:项目变更管理 一、项目变更管理内容二、项目变更管理基本概念1.项目变更管理定义2.项目变更产生的原因3.项目变更的分类三、项目变更管理的原则和工作流程1.项目变更管理的原则2.变更管理的组织机构3.变更管理的工作程序四、项目变更管…...
【Vue3源码】第二章 effect功能的完善补充
【Vue3源码】第二章 effect功能的完善补充 前言 上一章节我们实现了effect函数的功能stop和onstop,这次来优化下stop功能。 优化stop功能 之前我们的单元测试中,stop已经可以成功停止了响应式更新(清空了收集到的dep依赖) st…...
CHAPTER 2 Web Server - apache(httpd)
Web Server - httpd2.1 http2.1.1 协议版本2.1.2 http报文2.1.3 web资源(web resource)2.1.4 一次完整的http请求处理过程2.1.5 接收请求的模型2.2 httpd配置2.2.1 MPM(多进程处理模块)1. 工作模式2. 切换MPM3. MPM参数配置2.2.2 主配置文件1. 基本配置2. 站点访问控制常见机制…...
【Vagrant】下载安装与基本操作
文章目录概述软件安装安装VirtualBox安装Vagrant配置环境用Vagrant创建一个VMVagrantfile文件配置常用命令概述 Vagrant是一个创建虚拟机的技术,是用来创建和管理虚拟机的工具,本身自己并不能创建管理虚拟机。创建和管理虚拟机必须依赖于其他的虚拟化技…...
常用类(五)System类
(1)System类常见方法和案例: (1)exit:退出当前程序 我们设计的代码如下所示: package com.ypl.System_;public class System_ {public static void main(String[] args) {//exit: 退出当前程序System.out.println("ok1"…...
Navicat Premium 安装 注册
Navicat Premium 一.Navicat Premium的安装 1.暂时关闭windows的病毒与威胁防护弄完再开,之后安装打开过程中弹窗所有警告全部允许,不然会被拦住 2.下载安装包,解压 链接:https://pan.baidu.com/s/1X24VPC4xq586YdsnasE5JA?pwdu4vi 提取码…...
回溯算法总结
首先回溯算法本身还是一个纯暴力的算法,只是回溯过程可能比较抽象,导致大家总是感觉看到的相关题目做的不是很顺畅,回溯算法一般来说解决的题目有以下几类:组合问题:lq77、lq17、lq39、lq40、lq216、切割问题ÿ…...
ccc-pytorch-基础操作(2)
文章目录1.类型判断isinstance2.Dimension实例3.Tensor常用操作4.索引和切片5.Tensor维度变换6.Broadcast自动扩展7.合并与分割8.基本运算9.统计属性10.高阶OP大伙都这么聪明,注释就只写最关键的咯1.类型判断isinstance 常见类型如下: a torch.randn(…...
独居老人一键式报警器
盾王居家养老一键式报警系统,居家养老一键式报警设备 ,一键通紧急呼救设备,一键通紧急呼救系统,一键通紧急呼救器 ,一键通紧急呼救终端,一键通紧急呼救主机终端产品简介: 老人呼叫系统主要应用于…...
软考案例分析题精选
试题一:阅读下列说明,回答问题1至问题4,将解答填入答题纸的对应栏内。某公司中标了一个软件开发项目,项目经理根据以往的经验估算了开发过程中各项任务需要的工期及预算成本,如下表所示:任务紧前任务工期PV…...
黑马点评项目扩展:为本地生活平台集成AI人脸生成会员头像功能
黑马点评项目扩展:为本地生活平台集成AI人脸生成会员头像功能 不知道你有没有发现,现在很多本地生活类App,比如我们熟悉的“黑马点评”,用户头像区总是千篇一律。要么是默认的灰色头像,要么就是随手拍的生活照&#x…...
手把手教你用通义千问3-VL-Reranker-8B:从安装到实战,小白也能做智能搜索
手把手教你用通义千问3-VL-Reranker-8B:从安装到实战,小白也能做智能搜索 1. 为什么你需要这个多模态重排序器 想象一下,你在管理一个大型电商平台。用户搜索"红色连衣裙",结果返回了500个商品。传统的搜索引擎只能根…...
Hogan.js数据绑定终极指南:5个简单步骤实现动态内容渲染
Hogan.js数据绑定终极指南:5个简单步骤实现动态内容渲染 【免费下载链接】hogan.js A compiler for the Mustache templating language 项目地址: https://gitcode.com/gh_mirrors/ho/hogan.js Hogan.js是一个专为Mustache模板语言设计的编译器,由…...
MiniCPM-o-4.5-nvidia-FlagOS学术写作助手:LaTeX公式与论文排版智能辅助
MiniCPM-o-4.5-nvidia-FlagOS学术写作助手:LaTeX公式与论文排版智能辅助 写论文,尤其是理工科的论文,最头疼的是什么?十有八九的科研人员和学生会告诉你:是LaTeX公式和排版。一个复杂的公式,代码敲半天&am…...
UI-TARS-desktop部署避坑指南:快速解决模型启动问题
UI-TARS-desktop部署避坑指南:快速解决模型启动问题 1. UI-TARS-desktop概述 1.1 核心功能与架构 UI-TARS-desktop是一款基于Qwen3-4B-Instruct-2507模型的多模态AI应用框架,采用vLLM推理引擎提供高效服务。该系统将大语言模型能力与桌面自动化操作相…...
AI绘画小白入门:基于Z-Image Turbo的二次元/火影风格图片生成全流程
AI绘画小白入门:基于Z-Image Turbo的二次元/火影风格图片生成全流程 1. 为什么选择Z-Image Turbo 如果你是一个动漫爱好者,想要尝试AI绘画但又被复杂的参数设置劝退,Z-Image Turbo可能是最适合你的入门选择。这个专门针对二次元和火影忍者风…...
OpenClaw汽车保养助手:Qwen2.5-VL-7B解析故障灯照片生成检修指南
OpenClaw汽车保养助手:Qwen2.5-VL-7B解析故障灯照片生成检修指南 1. 为什么需要汽车故障灯智能助手 上周我的车突然亮起了发动机故障灯,黄色警示图标在仪表盘上闪烁。作为一个非专业车主,我面临两个选择:要么花半天时间排队去4S…...
生物信息学避坑指南:Scissor算法参数alpha和cutoff的黄金设置法则
生物信息学避坑指南:Scissor算法参数alpha和cutoff的黄金设置法则 在单细胞数据分析领域,如何有效整合bulk RNA测序数据与单细胞数据一直是研究者面临的挑战。Scissor算法通过巧妙设计,能够从含有表型的bulk RNA数据中提取关键信息࿰…...
【毕业设计】SpringBoot+Vue+MySQL 养老智慧服务平台平台源码+数据库+论文+部署文档
摘要 随着社会老龄化进程的加快,养老服务需求日益增长,传统养老模式已无法满足现代社会的多元化需求。智慧养老服务平台通过整合信息技术与养老服务资源,能够有效提升养老服务的效率和质量,为老年人提供更便捷、个性化的服务。该…...
Arduino_QTouch库深度解析:AVR电容触摸驱动原理与工业实践
1. Arduino_QTouch 库深度解析:面向嵌入式工程师的 Qtouch 电容式触摸传感器驱动实践指南Atmel(现为 Microchip)Qtouch 技术是工业级电容式触摸感应方案的标杆之一,其核心优势在于高抗噪性、低功耗、强环境适应性及无需覆盖层的裸…...
