news 2026/5/23 14:17:25

蓝桥杯 162.通电(Prim算法)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
蓝桥杯 162.通电(Prim算法)

2015 年,全中国实现了户户通电。作为一名电力建设者,小明正在帮助一带一路上的国家通电。

这一次,小明要帮助 nn 个村庄通电,其中 1 号村庄正好可以建立一个发电站,所发的电足够所有村庄使用。

现在,这 nn 个村庄之间都没有电线相连,小明主要要做的是架设电线连接这些村庄,使得所有村庄都直接或间接的与发电站相通。

小明测量了所有村庄的位置(坐标)和高度,如果要连接两个村庄,小明需要花费两个村庄之间的坐标距离加上高度差的平方,形式化描述为坐标为(x1,y1x1​,y1​) 高度为 h1h1​ 的村庄与坐标为 (x2,y2x2​,y2​) 高度为 h2h2​ 的村庄之间连接的费用为

(x1−x2)2+(y1−y2)2+(h1−h2)2(x1​−x2​)2+(y1​−y2​)2​+(h1​−h2​)2

高度的计算方式与横纵坐标的计算方式不同。

由于经费有限,请帮助小明计算他至少要花费多少费用才能使这 nn 个村庄都通电。

输入描述

输入的第一行包含一个整数 nn ,表示村庄的数量。

接下来 nn 行,每个三个整数 x,y,hx,y,h,分别表示一个村庄的横、纵坐标和高度,其中第一个村庄可以建立发电站。

其中,1≤n≤1000,0≤x,y,h≤100001≤n≤1000,0≤x,y,h≤10000。

输出描述

输出一行,包含一个实数,四舍五入保留 2 位小数,表示答案。

输入输出样例

示例

输入

4 1 1 3 9 9 7 8 8 6 4 5 4

输出

17.41

这道题本质就是求最小生成树,这里我们用到Prim算法:

核心思想:

从任意一个起点顶点出发,每次选择当前已连接顶点集合未连接顶点集合中权值最小的边,将该未连接顶点纳入已连接集合;重复此过程,直到所有顶点都被纳入,最终形成的边集合即为最小生成树。

Prim算法示例演示(起点0)

import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.util.Arrays; public class Main { public static void main(String[] args) throws IOException { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); int n = Integer.parseInt(br.readLine()); int cun[][] = new int[n][3];//村庄信息 for (int i = 0; i < n; i++) { String s[] = br.readLine().split(" "); cun[i][0] = Integer.parseInt(s[0]); cun[i][1] = Integer.parseInt(s[1]); cun[i][2] = Integer.parseInt(s[2]); } double minleng = 0;//最短总长度 double juli[][] = new double[n][n];//各个村庄之间的距离 for (int i = 0; i < n; i++) { for (int j = 0; j < n; j++) { if (i == j) { juli[i][j] = Double.MAX_VALUE; } else { juli[i][j] = Math.sqrt(Math.pow(cun[i][0] - cun[j][0], 2) + Math.pow(cun[i][1] - cun[j][1], 2)) + Math.pow(cun[i][2] - cun[j][2], 2); } } } //Prim算法初始化 boolean intree[] = new boolean[n];//村庄是否加入当前的生成树中 intree[0] = true;//初始化村庄1 double dist[] = new double[n]; // 记录每个顶点到当前生成树的最小距离 Arrays.fill(dist, Double.MAX_VALUE); dist[0] = 0; for (int i = 1; i < n; i++) { dist[i] = juli[0][i]; } //Prim算法 for (int i = 1; i < n; i++) { int u = -1;// 找到“未访问且距离当前生成树最近”的顶点u double mindist = Double.MAX_VALUE;//u到当前生成树的最小距离 for (int j = 0; j < n; j++) { if (!intree[j] && dist[j] < mindist) { mindist = dist[j]; u = j; } } minleng += mindist; intree[u] = true; // 更新其他未访问顶点到生成树的最小距离 for (int j = 0; j < n; j++) { if (!intree[j] && juli[u][j] < dist[j]) { dist[j] = juli[u][j]; } } } String result = String.format("%.2f", minleng); System.out.println(result); } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/21 23:22:04

ContextMenuManager仿写文章Prompt

ContextMenuManager仿写文章Prompt 【免费下载链接】ContextMenuManager &#x1f5b1;️ 纯粹的Windows右键菜单管理程序 项目地址: https://gitcode.com/gh_mirrors/co/ContextMenuManager 核心要求 请基于ContextMenuManager项目&#xff0c;创作一篇结构新颖、语气…

作者头像 李华
网站建设 2026/5/21 21:08:44

AI原生应用中的增量学习:多任务学习

AI原生应用中的增量学习&#xff1a;多任务学习——让AI像人一样“持续成长” 一、引入&#xff1a;从Copilot的“进化”说起 清晨的咖啡馆里&#xff0c;程序员小陆正对着电脑发愁&#xff1a;他刚接手一个跨语言项目&#xff0c;需要用Python写后端逻辑&#xff0c;用Go做微服…

作者头像 李华
网站建设 2026/5/23 14:17:23

解锁Slick轮播隐藏技能:5分钟打造专属分页指示器设计

解锁Slick轮播隐藏技能&#xff1a;5分钟打造专属分页指示器设计 【免费下载链接】slick the last carousel youll ever need 项目地址: https://gitcode.com/GitHub_Trending/sl/slick 想要让你的slick轮播组件在众多网站中脱颖而出&#xff1f;分页指示器&#xff08;…

作者头像 李华
网站建设 2026/5/20 22:41:16

Ubuntu命令行部署GPT-SoVITS语音合成

Ubuntu命令行部署GPT-SoVITS语音合成 在远程服务器上做AI语音项目&#xff0c;最头疼的莫过于没有图形界面——WebUI打不开、操作全靠SSH终端。最近尝试在纯命令行环境下部署 GPT-SoVITS&#xff0c;这个目前非常火的少样本语音克隆系统&#xff0c;发现虽然官方提供了Web界面…

作者头像 李华
网站建设 2026/5/21 2:50:21

侧边栏革命:猫抓浏览器扩展如何用SidePanel API重塑资源嗅探体验

还在为浏览器扩展弹窗遮挡网页内容而烦恼吗&#xff1f;猫抓(cat-catch)扩展通过革命性的SidePanel&#xff08;侧边栏&#xff09;API应用&#xff0c;彻底解决了传统扩展交互的痛点。本文将带你深入了解这一创新设计如何重塑资源嗅探流程&#xff0c;以及普通用户如何快速上手…

作者头像 李华
网站建设 2026/5/17 6:18:41

LobeChat能否支持量子加密通信?信息安全前沿技术科普

LobeChat 与量子加密通信&#xff1a;一场关于未来的安全对话 在今天这个数据即资产的时代&#xff0c;每一次键盘敲击都可能暴露敏感信息——从个人健康咨询到企业战略会议&#xff0c;AI 聊天助手正悄然渗透进我们最私密的交流场景。LobeChat 作为一款广受欢迎的开源聊天界面…

作者头像 李华