博客
关于我
[bzoj1934][网络流-最小割]Vote 善意的投票
阅读量:112 次
发布时间:2019-02-26

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

??????n????????????????????????????????????????????????????????????????????????????????????????

??????

??????????

  • ???????????????
  • ?????????????????
  • ????

    ??????????????????????????

  • ????????????????????????????
  • ??????????????????????????????????????
  • ???????????????????????????????
  • ?????????????????????
  • ????

    import sysfrom collections import dequeclass Edge:    def __init__(self, to, rev, capacity):        self.to = to        self.rev = rev        self.capacity = capacityclass MinCut:    def __init__(self, n):        self.size = n        self.graph = [[] for _ in range(n)]        def add_edge(self, fr, to, cap):        forward = Edge(to, len(self.graph[to]), cap)        backward = Edge(fr, len(self.graph[fr]), 0)        self.graph[fr].append(forward)        self.graph[to].append(backward)        def bfs_level(self, s, t, level):        q = deque()        level[:] = [-1]*self.size        level[s] = 0        q.append(s)        while q:            v = q.popleft()            for edge in self.graph[v]:                if edge.capacity > 0 and level[edge.to] == -1:                    level[edge.to] = level[v] + 1                    q.append(edge.to)                    if edge.to == t:                        return        return        def dfs_flow(self, v, t, upTo, iter_, level):        if v == t:            return upTo        for i in range(iter_[v], len(self.graph[v])):            edge = self.graph[v][i]            if edge.capacity > 0 and level[v] < level[edge.to]:                d = self.dfs_flow(edge.to, t, min(upTo, edge.capacity), iter_, level)                if d > 0:                    edge.capacity -= d                    self.graph[edge.to][edge.rev].capacity += d                    return d            iter_[v] +=1        return 0        def min_cut(self, s, t):        level = [-1]*self.size        self.bfs_level(s, t, level)        if level[t] == -1:            return 0        iter_ = [0]*self.size        flow = self.dfs_flow(s, t, float('inf'), iter_, level)        return flowdef main():    n, m = map(int, sys.stdin.readline().split())    a = list(map(int, sys.stdin.readline().split()))    edges = [[] for _ in range(n)]    for _ in range(m):        u, v = map(int, sys.stdin.readline().split())        u -=1        v -=1        edges[u].append(v)        edges[v].append(u)        size = 2 * n    source = 0    sink = 2 * n -1    mc = MinCut(size)    for i in range(n):        mc.add_edge(source, 2*i, a[i])        mc.add_edge(2*i +1, sink, 1)        for u in range(n):        for v in edges[u]:            mc.add_edge(2*u, 2*v, 1)            mc.add_edge(2*v, 2*u, 1)        min_flow = mc.min_cut(source, sink)    print(min_flow)if __name__ == "__main__":    main()

    ????

  • MinCut??????????????????
  • add_edge????????
  • bfs_level????????????????
  • dfs_flow??????????????
  • min_cut???????
  • main??????????????????
  • ???????????????????????

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

    你可能感兴趣的文章
    OSPF技术连载19:深入解析OSPF特殊区域
    查看>>
    SQL Server 复制 订阅与发布
    查看>>
    OSPF技术连载20:OSPF 十大LSA类型,太详细了!
    查看>>
    OSPF技术连载21:OSPF虚链路,现代网络逻辑连接的利器!
    查看>>
    OSPF技术连载22:OSPF 路径选择 O > O IA > N1 > E1 > N2 > E2
    查看>>
    OSPF技术连载2:OSPF工作原理、建立邻接关系、路由计算
    查看>>
    OSPF技术连载5:OSPF 基本配置,含思科、华为、Junifer三厂商配置
    查看>>
    OSPF技术连载6:OSPF 多区域,近7000字,非常详细!
    查看>>
    OSPF技术连载7:什么是OSPF带宽?OSPF带宽参考值多少?
    查看>>
    OSPF技术连载8:OSPF认证:明文认证、MD5认证和SHA-HMAC验证
    查看>>
    OSPF故障排除技巧
    查看>>
    spring配置文件中<context:property-placeholder />的使用
    查看>>
    OSPF有哪些优势?解决了RIP的什么问题?
    查看>>
    OSPF理论
    查看>>
    OSPF的七种类型LSA
    查看>>
    OSPF的安全性考虑:全面解析与最佳实践
    查看>>
    OSPF知识点大全,网络工程师快速收藏!
    查看>>
    ospf综合实验2 2012/9/8
    查看>>
    OSPF规划两大模型:双塔奇兵、犬牙交错
    查看>>
    OSPF认证
    查看>>