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

【算法】普里姆算法解决修路问题

 应用场景——修路问题

1.某地有 7 个村庄(A,B,C,D,E,F,G),现在需要修路把 7 个村庄连通

2.各个村庄的距离用边线表示(权),比如 A - B 距离 5 公里

3.问:如何修路保证各个村庄都能连通,并且修建公路的总里程最少?

思路

尽可能选择少的路线,并且每条路线最小,保证里程数最少

最小生成树问题

修路问题的本质就是最小生成树问题,先介绍一下最小生成树(MST)

1.给定一个带权的无向连通图,如何选取一颗生成树,使树上所有边上权的总和为最小,这叫最小生成树

2.N 个顶点,一定有 N-1 条边

3.包含全部顶点

4.N-1 条边都在图中

普里姆算法介绍

一、普里姆算法求最小生成树,也就是在包含 n 个顶点的连通图中,找出只有 n-1 条边包含所有 n 个顶点的连通子图,也就是所谓的极小连通子图

二、普里姆的算法如下

  1. 设 G=(V,E) 是连通网,T=(U,D) 是最小生成树,V,U 是顶点集合,E,D是边的集合
  2. 若从顶点 u 开始构造最小生成树,则从集合 V 中取出顶点 u 放入到集合 U 中,标记顶点 v 的 visited[u]=1
  3. 若集合 U 中顶点 ui 与集合 V - U 中的顶点 vj 之间存在边,则寻找这些边中权值最小的边,但不能构成回路,将顶点 vj 加入集合 U 中,将边(ui,vj) 加入集合 D 中,标记 visited[vj]=1
  4. 重复步骤2,直到 U 与 V 相等,即所有顶点都被标记为访问过,此时 D 中有 n-1 条边
普里姆算法的分析

1.从 <A> 顶点开始处理 => <A,G> => 权值 2

2.从 <A,G> 开始,将 A 和 G 顶点和他们相邻的还没有访问的顶点进行处理 => <A,G,B>

3.从 <A,G,B> 开始,将 A,G,B 顶点和他们相邻的还没有访问的顶点进行处理 => <A,G,B,E>

......

6.从 <A,G,B,E,F,D> 开始,将 A,G,B,E,F,D 顶点和他们相邻的还没有访问的顶点进行处理 => <A,G,B,E,F,D,C>

public class PrimAlgorithm {public static void main(String[] args) {//测试图是否创建成功char[] data = {'A', 'B', 'C', 'D', 'E', 'F', 'G'};int verxs = data.length;//邻接矩阵的关系使用二维数组表示,用 10000 表示两点之间不连通int[][] weight = {{10000, 5, 7, 10000, 10000, 10000, 2},{5, 10000, 10000, 9, 10000, 10000, 3},{7, 10000, 10000, 10000, 8, 10000, 10000},{10000, 9, 10000, 10000, 10000, 4, 10000},{10000, 10000, 8, 10000, 10000, 5, 4},{10000, 10000, 10000, 4, 5, 10000, 6},{2, 3, 10000, 10000, 4, 6, 10000}};//创建一个 MGraph 对象MGraph graph = new MGraph(verxs);//创建一个 MinTree 对象MinTree minTree = new MinTree();minTree.createGraph(graph, verxs, data, weight);//输出minTree.showGraph(graph);//测试普里姆算法minTree.prim(graph, 0);}
}//创建最小生成树 -> 村庄的图
class MinTree {//创建图的邻接矩阵/*** @param graph  图对象* @param verxs  图对应的顶点个数* @param data   图的各个顶点的值* @param weight 图的邻接矩阵*/public void createGraph(MGraph graph, int verxs, char[] data, int[][] weight) {for (int i = 0; i < verxs; i++) {graph.data[i] = data[i];for (int j = 0; j < verxs; j++) {graph.weight[i][j] = weight[i][j];}}}//显示图的邻接矩阵public void showGraph(MGraph graph) {for (int[] link : graph.weight) {System.out.println(Arrays.toString(link));}}//编写 prim 算法得到最小生成树/*** @param graph 图* @param v     v 表示从第几个顶点开始生成*/public void prim(MGraph graph, int v) {//visited[] 标记节点是否被访问过int visited[] = new int[graph.verxs];//把当前节点标记为已访问visited[v] = 1;//h1 和 h2 记录两个顶点的下标int h1 = -1;int h2 = -1;int minWeight = 10000;  //将 minWeight 初始成一个大数在后面的遍历过程中会被替换for (int k = 1; k < graph.verxs; k++) {  //因为有 graph.verxs 顶点,普利姆算法结束后,有graph.verxs-1条边//确定每一次生成的子图和哪个节点最近for (int i = 0; i < graph.verxs; i++) {  //i 节点表示被访问过的节点for (int j = 0; j < graph.verxs; j++) {  //j 节点表示没有被访问过的节点if (visited[i] == 1 && visited[j] == 0 && graph.weight[i][j] < minWeight) {//替换 minWeight (寻找已经访问过的节点间的权值最小的边)minWeight = graph.weight[i][j];h1 = i;h2 = j;}}}//找到一条边是最小System.out.println("边<" + graph.data[h1] + "," + graph.data[h2] + "> 权值:" + minWeight);//将当前这个节点标记为已经访问visited[h2] = 1;//minWeight 重新设置为最大值 10000minWeight = 10000;}}
}class MGraph {int verxs;  //表示图的节点个数char[] data;  //存放节点数据int[][] weight;  //存放边,就是我们的邻接矩阵public MGraph(int verxs) {this.verxs = verxs;data = new char[verxs];weight = new int[verxs][verxs];}
}

相关文章:

【算法】普里姆算法解决修路问题

应用场景——修路问题 1.某地有 7 个村庄&#xff08;A&#xff0c;B&#xff0c;C&#xff0c;D&#xff0c;E&#xff0c;F&#xff0c;G&#xff09;&#xff0c;现在需要修路把 7 个村庄连通 2.各个村庄的距离用边线表示&#xff08;权&#xff09;&#xff0c;比如 A - …...

Python 之Scikit-learn(二) -- Scikit-learn标准化数据

在机器学习中&#xff0c;数据标准化是一项关键的预处理步骤。标准化&#xff08;Standardization&#xff09;是将数据转换为具有均值为0和标准差为1的分布。这样可以确保特征在相同的尺度上&#xff0c;有助于提升某些机器学习算法的性能和稳定性。 Scikit-learn提供了一个简…...

机械学习—零基础学习日志(python编程)

零基础为了学人工智能&#xff0c;正在艰苦的学习 昨天给高等数学的学习按下暂停键&#xff0c;现在开始学习python编程。 我学习的思路是直接去阿里云的AI学习课堂里面学习。 整体感觉&#xff0c;阿里云的AI课堂还是有一些乱&#xff0c;早期课程和新出内容没有更新和归档…...

WEB应用(十三)---RCE

什么是RCE&#xff1f; Remote Command/Code Execute&#xff0c;远程命令或代码执行。通过构造特殊的字符串&#xff0c;将数据提交至Web应用程序&#xff0c;并利用该方式执行外部程序或系统命令实施攻击&#xff0c;类似于SQL注入。 Web应用程序使用了一些可以执行系统命令或…...

【云原生】Service服务暴露详细

Service服务 文章目录 Service服务一、Service介绍1.1、介绍1.2、Kubernetes中的Service 二、Service服务类型2.1、ClusterIP2.2、NodePort2.3、LadBalancer2.4、ExternalName 三、Service玩法3.1、定义Service3.2、端口定义别名3.3、多端口Service 四、Service类型4.1、Cluste…...

实名认证次数限制

在业务层实现实名认证次数限制 这个功能是通过以下步骤实现实名认证的次数限制&#xff1a; 每日失败尝试次数限制&#xff1a;限制用户每天可以尝试失败的次数。失败后的冷却时间&#xff1a;用户在连续失败几次后需要等待一段时间才能再次尝试。成功认证后的限制&#xff1…...

【如何在Python中使用pathlib模块】

在Python中使用pathlib模块主要涉及创建Path对象&#xff0c;并利用这些对象提供的方法来执行文件系统的各种操作。以下是一些详细的步骤和示例&#xff0c;帮助你了解如何在Python中有效地使用pathlib模块。 1. 导入Path类 首先&#xff0c;从pathlib模块中导入Path类。 fr…...

sqli-labs第一关详细解答

首先判断是否有注入点 发现and 11 和 and 12结果一样&#xff0c;所以应该是字符型注入&#xff0c;需要对单引号做闭合 做闭合后发现报错&#xff0c;提示Limit 0,1&#xff0c;那就说明存在注入点&#xff0c;但是要注释掉后面的limit 0,1 使用--注释掉limit 0,1后&#xff…...

分布式事务一站式解决方案-Seata

分布式事务一站式解决方案- 分布式事务一站式解决方案分布式事务产生背景三个概念Seata下载和安装实际业务模拟演示不加 GlobalTransactional 注解&#xff0c;正常操作下单不加 GlobalTransactional 注解&#xff0c;下单过程出异常或者超时了加 GlobalTransactional 注解&…...

openwrt 使用ftace工具追踪协议栈转发流程

开这四个宏 CONFIG_KERNEL_DYNAMIC_FTRACEy CONFIG_KERNEL_FTRACEy CONFIG_KERNEL_FUNCTION_GRAPH_TRACERy CONFIG_KERNEL_FUNCTION_TRACERy 如果/sys/kernel/debug/tracing没有&#xff0c;可以挂载 mount -t debugfs nodev /sys/kernel/debug 挂载报错&#xff1a; mo…...

ElasticSearch优化实战:打造高性能搜索引擎的秘籍

在当今这个大数据时代&#xff0c;信息的海量增长对搜索技术提出了前所未有的挑战。用户不仅需要快速准确地从数以亿计的数据中找到所需信息&#xff0c;还希望搜索引擎能够提供个性化和智能化的搜索体验。ElasticSearch作为市场上领先的搜索引擎&#xff0c;因其强大的全文搜索…...

【STL】| C++ 栈和队列(详解、容器适配器的初步引入)

目录 前言 总代码 容器适配器的引入 栈 stack 队列 queue 栈和队列用法简介 栈 队列 deque简介&#xff08;了解即可&#xff09; 结语 前言 今天我们要讲解的结构是栈和队列 这两个的具体实现相比于前面我们学的string、vector、list都要简单得多&#xff08;因为容…...

xss漏洞(二,xss靶场搭建以及简单利用)

本文仅作为学习参考使用&#xff0c;本文作者对任何使用本文进行渗透攻击破坏不负任何责任。 一&#xff0c;环境搭建。 使用工具&#xff1a;PHP study&#xff0c;dvwa靶场。 1&#xff0c;GitHub上下载dvwa到PHP study的WWW文件夹内&#xff0c;并解压。 dvwa下载地址 …...

深度学习--------------Kaggle房价预测

目录 下载和缓存数据集访问和读取数据集总代码 数据预处理训练K折交叉验证模型选择总代码提交你的Kaggle预测提交Kaggle 下载和缓存数据集 import hashlib import os import tarfile import zipfile import requests# download传递的参数分别是数据集的名称、缓存文件夹的路径…...

cpio 命令

前言 cpio&#xff08;Copy In and Out&#xff09;是一种在类 Unix 操作系统中处理归档文件的多功能工具。与 tar 不同&#xff0c;cpio 有其独特的优势和使用场景&#xff0c;特别是在与其他命令结合使用时。本文将带你了解 cpio 的基础知识、用法及实际示例。 什么是 cpio…...

TreeMap自定义排序

我们都知道TreeMap可以根据key按字典升序排序。但在某些场景下&#xff0c;我们需要自定义排序规则&#xff0c;为了代码优雅一些&#xff0c;我们也希望在stream中groupingBy时自定义排序规则&#xff0c;就可以参考本文的实现。 1. 使用TreeMap默认的排序规则&#xff08;按…...

我的CSDN 512天创作纪念日-20240807

机缘 在 2023 年 3 月 13 日&#xff0c;我撰写了第一篇技术博客《软考高级-系统分析师-案例分析-系统维护与设计模式》。那一天&#xff0c;我决定将自己的实战项目经验和学习心得记录下来&#xff0c;与更多志同道合的朋友分享。成为一名专业 IT 作者的梦想&#xff0c;促使我…...

微服务-实现nacos的集群和Gateway网关的实现、认证校验、解决跨域

1. nacos的集群模式 1.1 分析 nacos在企业中的使用100%都是集群模式。需要掌握nacos集群的搭建 nacos的数据存放在derby本地磁盘中&#xff0c;nacos集群模式会导致数据库数据不一致&#xff0c;使用加一层思想&#xff0c;修改nacos的数据库&#xff0c;使用mysql数据库&…...

数据库中的约束,聚合函数以及联合查询

目录 数据库中的约束 not null unique default primary key foreign key 表的设计 聚合函数&#xff08;查询&#xff09; 分组 联表查询&#xff08;多表查询&#xff09; 内连接 外连接 左外连接 右外连接 自连接 子查询 合并查询 数据库中的约束 为了保证…...

【AI大模型】Ollama+OpenWebUI+llama3本地大模型

本地部署大模型 0.引言1.部署安装1.1部署工具1.2 概念介绍1.3 ollama安装后的基本使用1.4 大模型权重下载1.4.1 ollama在线下载1.4.2 huggingFace下载大模型权重及如何使用ollama进行调用 2.带有UI界面的使用3.参考 0.引言 &#xff08;1&#xff09;目的 本教程主要关于开源A…...

终极指南:如何为QuaggaJS构建自定义条形码扫描插件

终极指南&#xff1a;如何为QuaggaJS构建自定义条形码扫描插件 【免费下载链接】quaggaJS An advanced barcode-scanner written in JavaScript 项目地址: https://gitcode.com/gh_mirrors/qu/quaggaJS QuaggaJS是一款强大的JavaScript条形码扫描库&#xff0c;它允许开…...

终极指南:gallery本地AI模型平台的架构演进与技术发展历程

终极指南&#xff1a;gallery本地AI模型平台的架构演进与技术发展历程 【免费下载链接】gallery A gallery that showcases on-device ML/GenAI use cases and allows people to try and use models locally. 项目地址: https://gitcode.com/GitHub_Trending/gallery44/galle…...

AI赋能前端开发:让快马平台智能生成仪表盘页面架构与代码

最近在做一个数据可视化项目时&#xff0c;遇到了一个典型的前端开发需求&#xff1a;需要快速搭建一个专业级的仪表盘页面。这个页面需要包含数据概览卡片、图表展示区和用户留言列表三大核心模块。作为一个独立开发者&#xff0c;既要考虑UI美观度&#xff0c;又要兼顾代码质…...

拯救你的网站兼容性:手把手教你用heic2any解决苹果图片上传问题

苹果用户图片上传难题的终极解决方案&#xff1a;前端HEIC转换实战指南 你是否遇到过这样的场景&#xff1a;精心设计的网站上传功能&#xff0c;在苹果用户面前却频频报错&#xff1f;后台服务器不断收到无法识别的图片格式&#xff0c;而用户则抱怨"明明能拍照片却上传…...

别再纠结了!手把手教你用FreeSWITCH 1.10 + Verto模块搭建WebRTC智能外呼系统(含完整配置文件)

WebRTC智能外呼实战&#xff1a;基于FreeSWITCH与Verto的高效解决方案 在数字化转型浪潮中&#xff0c;企业通信系统正经历从传统电话向互联网融合的深刻变革。我曾为多家金融机构和电商平台设计过智能外呼系统&#xff0c;发现一个共性痛点&#xff1a;如何在不依赖客户端安装…...

seo发布网站和传统推广方式相比有什么优势

SEO发布网站与传统推广方式相比有哪些优势 在当今数字化时代&#xff0c;网络已经成为人们获取信息和消费产品的重要途径。如何在众多的网站中脱颖而出&#xff0c;吸引更多的目标用户&#xff0c;是每一个企业和品牌都面临的问题。在这种背景下&#xff0c;SEO发布网站和传统…...

如何用5步告别Mac菜单栏混乱?Ice帮你打造高效工作空间

如何用5步告别Mac菜单栏混乱&#xff1f;Ice帮你打造高效工作空间 【免费下载链接】Ice Powerful menu bar manager for macOS 项目地址: https://gitcode.com/GitHub_Trending/ice/Ice 你是否曾因Mac菜单栏上密密麻麻的图标而感到焦虑&#xff1f;随着工作时间的推移&a…...

终极Win11优化指南:用Win11Debloat快速清理系统,性能提升70%

终极Win11优化指南&#xff1a;用Win11Debloat快速清理系统&#xff0c;性能提升70% 【免费下载链接】Win11Debloat A simple, lightweight PowerShell script that allows you to remove pre-installed apps, disable telemetry, as well as perform various other changes to…...

FreeCAD Sketcher模块实战:从零开始设计一个机械零件(附约束技巧)

FreeCAD Sketcher模块实战&#xff1a;从零开始设计一个机械零件&#xff08;附约束技巧&#xff09; 在三维CAD设计领域&#xff0c;参数化建模已经成为现代机械设计的标配技能。作为开源CAD软件中的佼佼者&#xff0c;FreeCAD凭借其强大的Sketcher模块&#xff0c;让用户能够…...

小米扫地机器人固件系统架构与功能解析

平台采用某米1代扫地机。 stm32f103真实项目程序。 c原程序 keil工程。 目前只有32端代码能实现延边避障防跌落充电等功能。适合需要学习项目与代码规范的工程师 硬件驱动包含 陀螺仪姿态传感器bmi160、电源管理bq24733等。 软件驱动包括 IIC、PWM、SPI、多路ADC与DMA、编码器输…...