zoukankan      html  css  js  c++  java
  • 笔记:网络流-基本知识

    容量网络的定义

    设一个有向连通图(N=langle V,E angle),记(n=|V|,m=|E|).

    ·容量:每条边(langle i,j angle)都对应一个非负实数(c(i,j))

    ·(N)有两个特殊顶点(s)(t)(s)称作发点(或Source),(t)称作收点(或Termination).其余的顶点称作中间节点

    ·称(N)容量网络,记作(N=langle V,E,c,s,t angle).

    容量网络上的可行流与最大流

    (f:E ightarrow mathbb{R} ^*),其中(mathbb{R} ^*)为非负实数集

    容量限制

    [forall langle i,j angle in E, f(i,j)le c(i,j) ]

    平衡条件

    [forall iin V-{s,t}\ sum_{langle j,i angle in E}f(j,i)=sum_{langle i,j angle in E}f(i,j) ]

    满足以上条件的,称(f)(N)上的一个可行流。称发点(s)的净流出量为(f)流量,记作(v(f)),即:

    [v(f)=sum_{langle s,j angle in E}f(s,j)-sum_{langle j,s angle in E}f(j,s) ]

    最大流

    流量最大的可行流称作最大流,求给定容量网络(N)上的最大流(f^*)的问题,称作最大流问题

    网络流建模

    多源/多汇问题

    具有多个源和多个汇的网络,可以通过在源之前(或者汇之后)添加一个节点的方式转换为单源单汇问题,如下图

    正向边反向边共存问题

    如果两个顶点之间有方向相反的两条边连接,可以在其中一条边上增加一个顶点(如下图绿色顶点),这样可以保证每两个顶点之间只有一条边。

    最大流问题的线性规划表述

    一个最大流问题可以描述成如下的LP模型

    [max v(f)\ { m s.t.}quadquad f(i,j)le c(i,j), langle i,j angle in E \ sum_{langle j,i angle in E}f(j,i)-sum_{langle i,j angle in E}f(i,j)=0, forall iin V-{s,t}\ v(f)-sum_{langle s,j angle in E}f(s,j)+sum_{langle j,s angle in E}f(j,s)=0, f(i,j)ge 0, langle i,j angle in E \ v(f)ge 0 ]

    割集、割集的容量、最小割集

    设容量网络(N=langle V,E,c,s,t angle,Asubset V)(sin A, tin overline A),称:

    [(A,overline A)={langle i,j angle|langle i,j anglein E且iin A,jin overline A} ]

    (N)割集;割集可以这么理解:将这个网络划分为两个部分,源(s)位于其中一个部分,汇(t)位于另一部分,而这两个部分相互不连通,为了使这两部分不连通所需要砍掉的边构成的集合就是割集。

    称:

    [c(A,overline A)=sum_{langle i,j angle in (A,overline A)}c(i,j) ]

    为割集((A,overline A))容量。容量最小的割集称作最小割集

  • 相关阅读:
    至少有K个重复字符的最长字串 分治法+递归
    旋转数组
    旋转链表 指针移动
    通过删除字母匹配到字典里最长的单词
    How to fix yum after CentOS 6 went EOL
    Centos6 yum源配置(CentOS 6停止更新)
    ORACLE 12C R2 RAC 安装配置指南
    Background Processes Specific to Oracle RAC
    如何缩小 Oracle 数据库中的临时表空间
    Script To Get Tablespace Utilization In Oracle Database 12c
  • 原文地址:https://www.cnblogs.com/allegro-vivace/p/12633000.html
Copyright © 2011-2022 走看看