博客
关于我
hdu6201 transaction transaction transaction(新建源汇点,带负权最长路)
阅读量:250 次
发布时间:2019-03-01

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

为了解决这个问题,我们需要找到树中的两个不同的点S和T,使得表达式a(T) - a(S) - dist(S, T)的值最大化。树的结构和权值特性使得这个问题可以通过构建有向图来解决。

方法思路

  • 构建有向图:创建一个源点0和一个汇点n+1。将每个节点i连接到源点0,边权为 -a(i),并将每个节点i连接到汇点n+1,边权为a(i)。同时,将原树结构中的每条边转换为两条有向边,权重为负数。
  • 计算最短路径:使用SPFA算法计算源点0到汇点n+1的最短路径。这个路径的总长度即为目标函数的最大值。
  • 解决代码

    import sysfrom collections import dequedef main():    sys.setrecursionlimit(1 << 25)    n = int(sys.stdin.readline())    a = [0] * (n + 2)    for i in range(1, n+1):        a[i] = int(sys.stdin.readline())        maxm = 1e5 + 5    head = [0] * (maxm + 2)    nt = [0] * (maxm + 2)    to = [0] * (maxm + 2)    w = [0] * (maxm + 2)    tot = 0    def add(x, y, z):        nonlocal tot        tot += 1        head[x] = tot        nt[tot] = y        to[tot] = y        w[tot] = z        def spfa(start):        q = deque()        q.append(start)        d = [-float('inf')] * (maxm + 2)        d[start] = 0        in_queue = [False] * (maxm + 2)        in_queue[start] = True        while q:            u = q.popleft()            in_queue[u] = False            for i in range(head[u], -1, -1):                v = to[i]                if d[v] > d[u] + w[i]:                    d[v] = d[u] + w[i]                    if not in_queue[v]:                        q.append(v)                        in_queue[v] = True        return d        add(0, 0, 0)    for i in range(1, n+1):        add(0, i, -a[i])        add(n+1, n+1, 0)    for i in range(1, n+1):        add(i, n+1, a[i])        for i in range(1, n+1):        u = nt[i]        v = to[i]        if u != -1 and v != -1:            add(u, v, -1)            add(v, u, -1)        d = spfa(0)    print(d[n+1])if __name__ == '__main__':    main()

    代码解释

  • 读取输入:读取节点数n和每个节点的权值a(i)。
  • 构建有向图:将每个节点连接到源点0和汇点n+1,并处理原树结构中的每条边。
  • SPFA算法:计算源点0到汇点n+1的最短路径,更新每个节点的最短距离。
  • 输出结果:输出源点0到汇点n+1的最短路径长度,即目标函数的最大值。
  • 通过这种方法,我们能够高效地解决问题,适用于大规模数据。

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

    你可能感兴趣的文章
    Node-RED中使用JSON数据建立web网站
    查看>>
    Node-RED中使用json节点解析JSON数据
    查看>>
    Node-RED中使用node-random节点来实现随机数在折线图中显示
    查看>>
    Node-RED中使用node-red-browser-utils节点实现选择Windows操作系统中的文件并实现图片预览
    查看>>
    Node-RED中使用Notification元件显示警告讯息框(温度过高提示)
    查看>>
    Node-RED中实现HTML表单提交和获取提交的内容
    查看>>
    Node.js 8 中的 util.promisify的详解
    查看>>
    Node.js 函数是什么样的?
    查看>>
    Node.js 历史
    查看>>
    Node.js 在个推的微服务实践:基于容器的一站式命令行工具链
    查看>>
    Node.js 实现类似于.php,.jsp的服务器页面技术,自动路由
    查看>>
    node.js 怎么新建一个站点端口
    查看>>
    Node.js 文件系统的各种用法和常见场景
    查看>>
    node.js 简易聊天室
    查看>>
    node.js 配置首页打开页面
    查看>>
    node.js+react写的一个登录注册 demo测试
    查看>>
    Node.js中环境变量process.env详解
    查看>>
    Node.js卸载超详细步骤(附图文讲解)
    查看>>
    Node.js安装与配置指南:轻松启航您的JavaScript服务器之旅
    查看>>
    Node.js安装及环境配置之Windows篇
    查看>>