博客
关于我
Command Network POJ - 3164(最小树形图/朱刘算法)
阅读量:275 次
发布时间:2019-03-01

本文共 2186 字,大约阅读时间需要 7 分钟。

为了解决这个问题,我们需要构建一个最小的树形图,使得所有节点都能收到命令。这个问题可以通过最小生成树算法来解决,特别是使用Kruskal算法来处理有向图中的边。

方法思路

  • 读取输入:首先读取输入数据,包括节点的坐标和边的信息。
  • 计算权重:将每条边的权重计算为两点之间的欧几里得距离。
  • 检测环:检查是否存在环路,如果存在环路,则无法构造有效的通信网络。
  • Kruskal算法:使用Kruskal算法来构建最小生成树,确保所有节点都连通,并且总权重最小。
  • 输出结果:计算并输出最小生成树的总权重,或者输出“poor snoopy”如果无法构造有效的通信网络。
  • 解决代码

    import sys
    import math
    def readints():
    return list(map(int, sys.stdin.readline().split()))
    def main():
    n, m = 0, 0
    while True:
    line = sys.stdin.readline()
    if not line:
    break
    n, m = map(int, line.strip().split())
    break
    x = [0.0] * (n + 1)
    y = [0.0] * (n + 1)
    for i in range(1, n+1):
    line = sys.stdin.readline()
    xi, yi = map(float, line.strip().split())
    x[i] = xi
    y[i] = yi
    edges = []
    for _ in range(m):
    u, v = map(int, sys.stdin.readline().split())
    dx = x[u] - x[v]
    dy = y[u] - y[v]
    dist = math.hypot(dx, dy)
    edges.append((dist, u, v))
    edges.sort()
    parent = list(range(n+1))
    rank = [1] * (n+1)
    def find(u):
    while parent[u] != u:
    parent[u] = parent[parent[u]]
    u = parent[u]
    return u
    def union(u, v):
    u_root = find(u)
    v_root = find(v)
    if u_root == v_root:
    return False
    if rank[u_root] < rank[v_root]:
    parent[u_root] = v_root
    rank[v_root] += rank[u_root]
    else:
    parent[v_root] = u_root
    rank[u_root] += v_root
    return True
    total = 0.0
    count = 0
    edges_added = 0
    for dist, u, v in edges:
    if find(u) != find(v):
    union(u, v)
    edges_added += 1
    total += dist
    count += 1
    if count == n:
    break
    if count == n:
    print("{0:.2f}".format(total))
    else:
    print("poor snoopy")
    if __name__ == "__main__":
    main()

    代码解释

  • 读取输入:使用sys.stdin.readline读取输入数据,处理节点数和边数,然后读取节点坐标。
  • 计算边权重:对于每条边,计算其权重为两点之间的欧几里得距离。
  • 排序边:将所有边按权重从小到大排序,以便Kruskal算法处理。
  • 并查集初始化:初始化并查集数据结构,用于管理连通性。
  • Kruskal算法处理边:依次处理每条边,检查是否形成环。如果不形成环,则将边加入生成树,并更新总权重。
  • 输出结果:如果生成树包含所有节点,输出总权重;否则输出“poor snoopy”。
  • 通过这种方法,我们能够高效地解决问题,并确保构造的通信网络是最短的。

    转载地址:http://qqvo.baihongyu.com/

    你可能感兴趣的文章
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
    查看>>
    Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
    查看>>
    NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
    查看>>
    NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
    查看>>
    NIFI数据库同步_多表_特定表同时同步_实际操作_MySqlToMysql_可推广到其他数据库_Postgresql_Hbase_SqlServer等----大数据之Nifi工作笔记0053
    查看>>
    NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南001---大数据之Nifi工作笔记0068
    查看>>
    NIFI集群_内存溢出_CPU占用100%修复_GC overhead limit exceeded_NIFI: out of memory error ---大数据之Nifi工作笔记0017
    查看>>
    NIFI集群_队列Queue中数据无法清空_清除队列数据报错_无法删除queue_解决_集群中机器交替重启删除---大数据之Nifi工作笔记0061
    查看>>
    NIH发布包含10600张CT图像数据库 为AI算法测试铺路
    查看>>
    Nim教程【十二】
    查看>>
    Nim游戏
    查看>>
    NIO ByteBuffer实现原理
    查看>>
    Nio ByteBuffer组件读写指针切换原理与常用方法
    查看>>
    NIO Selector实现原理
    查看>>
    nio 中channel和buffer的基本使用
    查看>>
    NIO基于UDP协议的网络编程
    查看>>
    NISP一级,NISP二级报考说明,零基础入门到精通,收藏这篇就够了
    查看>>
    Nitrux 3.8 发布!性能全面提升,带来非凡体验
    查看>>
    NI笔试——大数加法
    查看>>