OD C卷 - 5G网络建设

2024-08-21 23:20
文章标签 建设 网络 od 5g

本文主要是介绍OD C卷 - 5G网络建设,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

5G网络建设 (200)

  • 选取n个地点建设5G基站,地点编号1 -> n;
  • 各个基站之间使用光纤连接,设计算法计算连通所有基站的最小成本;
  • 基站的连通具有传递性,A->B连通,B->C连通,则A->C连通;
    输入描述:
    第一行输入基站个数n, 0< n <=20;
    第二行输入已具备光纤连接的基站对数m;
    第三行开始的m行,格式为 X Y Z P,X Y表示基站编号 1-n且不相等,Z表示XY之间的光纤成本(0, 100),P表示是否已存在光纤连接,0未连接,1已连接;
    输出描述:
    输出最小的建设成本(所有基站连通),无法建设完成输出-1;

示例1
输入:
3
3
1 2 3 0
1 3 1 0
2 3 5 0
输出:
4
说明:只需在1、2及2、3之间建设光纤

示例2
输入:
3
1
1 2 5 0
输出:
-1

示例3
输入:
3
3
1 2 3 0
1 3 1 0
2 3 5 1
输出:
1

思路:

  • 并查集,实现图连通;
  • 并查集是一种高级数据结构,实现不相交集合的合并问题;
  • 步骤:
    • 初始化,每个节点的父(根)节点是自己;
    • find查找,查找每个节点的父节点,如果父节点是自己则返回自己,否则递归查找其父节点的父节点,将最终的父节点(即父为自己的节点)赋值作为前一个节点的父节点,并返回;
    • 合并,两个节点的父节点不一样,则合并,即其中一个节点所在集合的父节点->的父节点设置为另一个节点所在集合的父节点;
  • 本题思路:
    • 已连接的,只需合并,edges_num += 1;
    • 未连接的需要按照成本升序排序,然后依次建立连接,同时edges_num += 1 and total_cost += cur_cost;
    • edges_num == n - 1 则连通,否则无法连通;

class UF: # 并查集def __init__(self, n): # 1 初始化# 每个节点的父节点是自己self.fa = [i for i in range(n + 1)]self.edges = 0 # n个节点 n-1条边可以连通def find(self, x): # 2 查询节点的根# 当前节点的根,根为自己则returnif x == self.fa[x]:return x# 否则 递归查询根 (路径压缩)self.fa[x] = self.find(self.fa[x])return self.fa[x]def union(self, x, y): # 3 合并,两个集合的根不同,则合并self.fa[self.find(x)] = self.find(y)self.edges += 1 # 边数+1def get_edges(self):return self.edgesn = int(input())  # 总节点数
m = int(input())  # 连接数对
uf = UF(n)
networks = []for i in range(m): # m行data = [int(x) for x in input().strip().split()]if data[-1] == 1:# 已建立连接,使用并查集 进行合并(边+1 不计成本)if uf.find(data[0]) != uf.find(data[1]): # 根节点不同 则合并uf.union(data[0], data[1])else:# 尚未建立连接networks.append([data[0], data[1], data[2]]) # 成本即权重# 按照成本 升序排序
networks = sorted(networks, key=lambda x: x[2])total_cost = 0 # 成本
i = 0 # networks 列表索引
while True:if i >= len(networks):breakelse:# 对于尚未连接的基站,进行并查集 合并, 成本累加起来if uf.find(networks[i][0]) != uf.find(networks[i][1]): # 根节点不同,则合并# 不相交集合  的合并uf.union(networks[i][0], networks[i][1])# 成本累加total_cost += networks[i][2]# 连接的边数if uf.get_edges() == n - 1:  # n个节点 只需n-1条边 连通break# 继续合并第二组i += 1if uf.get_edges() != n - 1:total_cost = -1print(total_cost)

 

这篇关于OD C卷 - 5G网络建设的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1094577

相关文章

Debian 13升级后网络转发等功能异常怎么办? 并非错误而是管理机制变更

《Debian13升级后网络转发等功能异常怎么办?并非错误而是管理机制变更》很多朋友反馈,更新到Debian13后网络转发等功能异常,这并非BUG而是Debian13Trixie调整... 日前 Debian 13 Trixie 发布后已经有众多网友升级到新版本,只不过升级后发现某些功能存在异常,例如网络转

Python开发简易网络服务器的示例详解(新手入门)

《Python开发简易网络服务器的示例详解(新手入门)》网络服务器是互联网基础设施的核心组件,它本质上是一个持续运行的程序,负责监听特定端口,本文将使用Python开发一个简单的网络服务器,感兴趣的小... 目录网络服务器基础概念python内置服务器模块1. HTTP服务器模块2. Socket服务器模块

Go语言网络故障诊断与调试技巧

《Go语言网络故障诊断与调试技巧》在分布式系统和微服务架构的浪潮中,网络编程成为系统性能和可靠性的核心支柱,从高并发的API服务到实时通信应用,网络的稳定性直接影响用户体验,本文面向熟悉Go基本语法和... 目录1. 引言2. Go 语言网络编程的优势与特色2.1 简洁高效的标准库2.2 强大的并发模型2.

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

Linux网络配置之网桥和虚拟网络的配置指南

《Linux网络配置之网桥和虚拟网络的配置指南》这篇文章主要为大家详细介绍了Linux中配置网桥和虚拟网络的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 一、网桥的配置在linux系统中配置一个新的网桥主要涉及以下几个步骤:1.为yum仓库做准备,安装组件epel-re

python如何下载网络文件到本地指定文件夹

《python如何下载网络文件到本地指定文件夹》这篇文章主要为大家详细介绍了python如何实现下载网络文件到本地指定文件夹,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下...  在python中下载文件到本地指定文件夹可以通过以下步骤实现,使用requests库处理HTTP请求,并结合o

Linux高并发场景下的网络参数调优实战指南

《Linux高并发场景下的网络参数调优实战指南》在高并发网络服务场景中,Linux内核的默认网络参数往往无法满足需求,导致性能瓶颈、连接超时甚至服务崩溃,本文基于真实案例分析,从参数解读、问题诊断到优... 目录一、问题背景:当并发连接遇上性能瓶颈1.1 案例环境1.2 初始参数分析二、深度诊断:连接状态与

Qt实现网络数据解析的方法总结

《Qt实现网络数据解析的方法总结》在Qt中解析网络数据通常涉及接收原始字节流,并将其转换为有意义的应用层数据,这篇文章为大家介绍了详细步骤和示例,感兴趣的小伙伴可以了解下... 目录1. 网络数据接收2. 缓冲区管理(处理粘包/拆包)3. 常见数据格式解析3.1 jsON解析3.2 XML解析3.3 自定义

Linux系统配置NAT网络模式的详细步骤(附图文)

《Linux系统配置NAT网络模式的详细步骤(附图文)》本文详细指导如何在VMware环境下配置NAT网络模式,包括设置主机和虚拟机的IP地址、网关,以及针对Linux和Windows系统的具体步骤,... 目录一、配置NAT网络模式二、设置虚拟机交换机网关2.1 打开虚拟机2.2 管理员授权2.3 设置子

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.