热门标签 | HotTags
当前位置:  开发笔记 > 人工智能 > 正文

最小生成树_prim算法

P3366【模板】最小生成树题目描述如题,给出一个无向图,求出最小生成树,如果该图不连通,则输出 orz。输入格式第一行包含两个整数 N,MN,M,表示该图共有 NN 个结点和 M

文章目录[隐藏]

  • P3366 【模板】最小生成树
    • 题目描述
    • 输入格式
    • 输出格式
    • 输入输出样例
    • 说明/提示


P3366 【模板】最小生成树

题目描述

如题,给出一个无向图,求出最小生成树,如果该图不连通,则输出 orz

输入格式

第一行包含两个整数 N,MN,M,表示该图共有 NN 个结点和 MM 条无向边。

接下来 MM 行每行包含三个整数 X_i,Y_i,Z_iXi​,Yi​,Zi​,表示有一条长度为 Z_iZi​ 的无向边连接结点 X_i,Y_iXi​,Yi​。

输出格式

如果该图连通,则输出一个整数表示最小生成树的各边的长度之和。如果该图不连通则输出 orz

输入输出样例

输入 #1

4 5
1 2 2
1 3 2
1 4 3
2 3 4
3 4 3

输出 #1

7

说明/提示

数据规模:

对于 20/%20% 的数据,N/le 5N≤5,M/le 20M≤20。

对于 40/%40% 的数据,N/le 50N≤50,M/le 2500M≤2500。

对于 70/%70% 的数据,N/le 500N≤500,M/le 10^4M≤104。

对于 100/%100% 的数据:1/le N/le 50001≤N≤5000,1/le M/le 2/times 10^51≤M≤2×105,1/le Z_i /le 10^41≤Zi​≤104。

样例解释:

最小生成树_prim算法

所以最小生成树的总边权为 2+2+3=7。

【解析】

本题是一道板子题

首先先看一下prim算法的思路

最小生成树可以看作一个集合

用样例模拟下过程:

minn:每个节点的最小边权

白点:未进入集合的节点

蓝点:已进入集合的节点

红线:最小生成树的边

1.通过输入可以画出下面的图

最小生成树_prim算法

2.将图的各个节点赋初值  minn[1]=0,其余赋值为正无穷

3.找到最小边的点1,并加入生成的树(可以理解为一个集合)

最小生成树_prim算法

4.更改与节点1相连的节点边权的最小值

最小生成树_prim算法

5.找到集合外的最小边的节点2,并加入集合

最小生成树_prim算法

6.更改与节点2相连的节点边权的最小值

最小生成树_prim算法

7.找到集合外的最小边的节点3,并加入集合

最小生成树_prim算法

8.更改与节点3相连的节点边权的最小值

最小生成树_prim算法

9.找到集合外的最小边的节点4,并加入集合

最小生成树_prim算法

这时候有两种不同的树

最小生成树_prim算法

最小生成树_prim算法

10.更改与节点4相连的节点边权的最小值

最小生成树_prim算法

最小生成树_prim算法

上面的步骤整理一下就变成了:

        for(遍历每个节点){

              找到集合外最小的节点k(与集合有连边)

              更改与k相连的节点的最小值

        }

【代码】

这道题还需要注意判断图是否联通,有的边可能重复输入,要取最小的权值

最小生成树_prim算法


推荐阅读
  • 计算机学报精选论文概览(2020-2022)
    本文汇总了2020年至2022年间《计算机学报》上发表的若干重要论文,旨在为即将投稿的研究者提供参考。 ... [详细]
  • 在将 Android Studio 从 3.0 升级到 3.1 版本后,遇到项目无法正常编译的问题,具体错误信息为:org.gradle.api.tasks.TaskExecutionException: Execution failed for task ':app:processDemoProductDebugResources'。 ... [详细]
  • JavaScript中的if语句是编程基础之一,用于根据特定条件执行代码块。本文将详细介绍if语句的基本结构及其与else if和else语句的配合使用方法。 ... [详细]
  • 高效的JavaScript异步资源加载解决方案
    本文探讨了如何通过异步加载技术处理网页中大型第三方插件的加载问题,避免将大文件打包进主JS文件中导致的加载时间过长,介绍了实现异步加载的具体方法及其优化。 ... [详细]
  • Excel技巧:实现自定义排序功能
    在日常的数据处理中,除了常见的数字和字母排序外,有时还需要根据特定的标准(如职位等级、教育水平)对数据进行排序。这些非标准的排序规则通常需要用户自行定义。例如,如何在Excel中按照学历从高到低对人员信息进行排序? ... [详细]
  • PHP混淆代码的破解与理解
    本文探讨了PHP中常见的代码混淆技术及其破解方法,包括简单的变量名混淆和更复杂的加密技术。 ... [详细]
  • 编译原理中的语法分析方法探讨
    本文探讨了在编译原理课程中遇到的复杂文法问题,特别是当使用SLR(1)文法时遇到的多重规约与移进冲突。文章讨论了可能的解决策略,包括递归下降解析、运算符优先级解析等,并提供了相关示例。 ... [详细]
  • 本文旨在探讨设计模式在Visual FoxPro (VFP) 中的应用可能性。虽然VFP作为一种支持面向对象编程(xbase语言)的工具,其OO特性相对简明,缺乏高级语言如Java、C++等提供的复杂特性,但设计模式作为一种通用的解决方案框架,是否能有效应用于VFP,值得深入研究。 ... [详细]
  • 本文详细记录了腾讯ABS云平台的一次前端开发岗位面试经历,包括面试过程中遇到的JavaScript相关问题、Vue.js等框架的深入探讨以及算法挑战等内容。 ... [详细]
  • 深入解析JVM内存模型与分配机制
    本文详细探讨了JVM内存结构的主要组成部分,包括Java虚拟机栈、Java堆、方法区等,并深入分析了HotSpot虚拟机的分代收集策略及其对不同内存区域的管理方式。 ... [详细]
  • 本文详细介绍了二叉堆的概念及其在Java中的实现方法。二叉堆是一种特殊的完全二叉树,具有堆性质,常用于实现优先队列。 ... [详细]
  • 使用C#构建动态图形界面时钟
    本篇文章将详细介绍如何利用C#语言开发一个具有动态显示功能的图形界面时钟。文章中不仅提供了详细的代码示例,还对可能出现的问题进行了深入分析,并给出了解决方案。 ... [详细]
  • 深入解析JVM中的垃圾回收机制
    本文详细探讨了JVM中垃圾回收的几种主要算法及其工作原理,包括标记-清除、复制、标记-整理及分代收集算法,并简要介绍了常见的垃圾收集器。 ... [详细]
  • MATLAB是科技工作者的重要工具,以其强大的科学计算能力和简洁的编程风格而广受好评。然而,MATLAB生成的图形默认分辨率较低,这在某些情况下可能会影响图形的质量。本文将介绍如何在MATLAB中保存高分辨率的图形。 ... [详细]
  • Spring Boot使用AJAX从数据库读取数据异步刷新前端表格
      近期项目需要是实现一个通过筛选选取所需数据刷新表格的功能,因为表格只占页面的一小部分,不希望整个也页面都随之刷新,所以首先想到了使用AJAX来实现。  以下介绍解决方法(请忽视 ... [详细]
author-avatar
黑m泽猫咪2009
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有