博客
关于我
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/

    你可能感兴趣的文章
    Notadd —— 基于 nest.js 的微服务开发框架
    查看>>
    Notepad ++ 安装与配置教程(非常详细)从零基础入门到精通,看完这一篇就够了
    查看>>
    Notepad++在线和离线安装JSON格式化插件
    查看>>
    notepad++最详情汇总
    查看>>
    notepad如何自动对齐_notepad++怎么自动排版
    查看>>
    Notification 使用详解(很全
    查看>>
    NotImplementedError: Cannot copy out of meta tensor; no data! Please use torch.nn.Module.to_empty()
    查看>>
    Now trying to drop the old temporary tablespace, the session hangs.
    查看>>
    nowcoder—Beauty of Trees
    查看>>
    np.arange()和np.linspace()绘制logistic回归图像时得到不同的结果?
    查看>>
    np.power的使用
    查看>>
    NPM 2FA双重认证的设置方法
    查看>>
    npm build报错Cannot find module ‘webpack/lib/rules/BasicEffectRulePlugin‘解决方法
    查看>>
    npm build报错Cannot find module ‘webpack‘解决方法
    查看>>
    npm ERR! ERESOLVE could not resolve报错
    查看>>
    npm ERR! fatal: unable to connect to github.com:
    查看>>
    npm ERR! Unexpected end of JSON input while parsing near ‘...“:“^1.2.0“,“vue-html-‘ npm ERR! A comp
    查看>>
    npm error Missing script: “server“npm errornpm error Did you mean this?npm error npm run serve
    查看>>
    npm error MSB3428: 未能加载 Visual C++ 组件“VCBuild.exe”。要解决此问题,1) 安装
    查看>>
    npm install CERT_HAS_EXPIRED解决方法
    查看>>