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

    你可能感兴趣的文章
    numpy中的argsort的用法
    查看>>
    NumPy中的精度:比较数字时的问题
    查看>>
    numpy判断对应位置是否相等,all、any的使用
    查看>>
    Numpy多项式.Polynomial.fit()给出的系数与多项式.Polyfit()不同
    查看>>
    Numpy如何使用np.umprod重写range函数中i的python
    查看>>
    numpy学习笔记3-array切片
    查看>>
    numpy数组替换其中的值(如1替换为255)
    查看>>
    numpy数组索引-ChatGPT4o作答
    查看>>
    numpy最大值和最大值索引
    查看>>
    NUMPY矢量化np.prod不能构造具有超过32个操作数的ufunc
    查看>>
    Numpy矩阵与通用函数
    查看>>
    numpy绘制热力图
    查看>>
    numpy转PIL 报错TypeError: Cannot handle this data type
    查看>>
    Numpy闯关100题,我闯了95关,你呢?
    查看>>
    nump模块
    查看>>