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

    你可能感兴趣的文章
    PermissionError:Python 中的 [Errno 13]
    查看>>
    PermissionError:[Errno 13] 权限被拒绝:‘/manage.py‘
    查看>>
    Permutation
    查看>>
    perspective意思_2020年12月英语四级词汇讲解丨考点归纳:perspective
    查看>>
    PE文件,节头有感IMAGE_SECTION_HEADER
    查看>>
    PE查找文件偏移地址
    查看>>
    PE知识复习之PE的导入表
    查看>>
    PFX(Parallel Framework) and Traditional Multithreading
    查看>>
    PGOS:今天动手给电脑装青苹果Win7 X64位系统
    查看>>
    pgpool-II3.1 的内存泄漏(一)
    查看>>
    PgSQL · 特性分析 · PG主备流复制机制
    查看>>
    PGSQL主键序列
    查看>>
    PGSQL安装PostGIS扩展模块
    查看>>
    pg数据库中两个字段相除
    查看>>
    PhalApi:[1.23] 请求和响应:GET和POST两者皆可得及超越JSON格式返回
    查看>>
    Phalcon环境搭建与项目开发
    查看>>
    Phantom.js维护者退出,项目的未来成疑
    查看>>
    Pharmaceutical的同学们都看过来,关于补码运算的复习相关内容
    查看>>
    Phoenix 查看表信息及修改元数据
    查看>>
    Phoenix基础命令_视图映射和表映射_数字存储问题---大数据之Hbase工作笔记0036
    查看>>