费用流模板

我借鉴了一些大神的代码也就是他们经常用的模板。。。
费用流模板

#include<cstdio>
#include<iostream>
using namespace std;
const int oo=1e9;
const int mm=11111;
const int mn=888;
int node,src,dest,edge;
int ver[mm],flow[mm],cost[mm],next[mm];
int head[mn],dis[mn],p[mn],q[mn],vis[mn];
/**这些变量基本与最大流相同,增加了
cost 表示边的费用,
p 记录可行流上节点对应的反向边
*/
void prepare(int _node,int _src,int _dest)
{
    node=_node,src=_src,dest=_dest;
    for(int i=0; i<node; ++i)head[i]=-1,vis[i]=0;
    edge=0;
}
void addedge(int u,int v,int f,int c)
{
    ver[edge]=v,flow[edge]=f,cost[edge]=c,next[edge]=head[u],head[u]=edge++;
    ver[edge]=u,flow[edge]=0,cost[edge]=-c,next[edge]=head[v],head[v]=edge++;
}
/**以上同最大流*/
/**spfa 求最短路,并用p 记录最短路上的边*/
bool spfa()
{
    int i,u,v,l,r=0,tmp;
    for(i=0; i<node; ++i)dis[i]=oo;
    dis[q[r++]=src]=0;
    p[src]=p[dest]=-1;
    for(l=0; l!=r; (++l>=mn)?l=0:l)
        for(i=head[u=q[l]],vis[u]=0; i>=0; i=next[i])
            if(flow[i]&&dis[v=ver[i]]>(tmp=dis[u]+cost[i]))
            {
                dis[v]=tmp;
                p[v]=i^1;
                if(vis[v])continue;
                vis[q[r++]=v]=1;
                if(r>=mn)r=0;
            }
    return p[dest]>-1;
}
/**源点到汇点的一条最短路即可行流,不断的找这样的可行流*/
int SpfaFlow()
{
    int i,ret=0,delta;
    while(spfa())
    {
        /**按记录原路返回求流量*/
        for(i=p[dest],delta=oo; i>=0; i=p[ver[i]])
            if(flow[i^1]<delta)delta=flow[i^1];
        for(i=p[dest]; i>=0; i=p[ver[i]])
            flow[i]+=delta,flow[i^1]-=delta;
        ret+=delta*dis[dest];
    }
    return ret;
}

但是还有下面这个代码好像比上面的快一点。。。

#include <iostream>
#include <cstdio>

using namespace std;

const int oo=1e9;//无穷大
const int maxm=1111111;//边的最大数量,为原图的两倍
const int maxn=2222;//点的最大数量

int node,src,dest,edge;//node节点数,src源点,dest汇点,edge边数
int head[maxn],p[maxn],dis[maxn],q[maxn],vis[maxn];//head链表头,p记录可行流上节点对应的反向边,dis计算距离

struct edgenode
{
    int to;//边的指向
    int flow;//边的容量
    int cost;//边的费用
    int next;//链表的下一条边
} edges[maxm];

void prepare(int _node,int _src,int _dest);
void addedge(int u,int v,int f,int c);
bool spfa();

inline int min(int a,int b)
{
    return a<b?a:b;
}

inline void prepare(int _node,int _src,int _dest)
{
    node=_node;
    src=_src;
    dest=_dest;
    for (int i=0; i<node; i++)
    {
        head[i]=-1;
        vis[i]=false;
    }
    edge=0;
}

void addedge(int u,int v,int f,int c)
{
    edges[edge].flow=f;
    edges[edge].cost=c;
    edges[edge].to=v;
    edges[edge].next=head[u];
    head[u]=edge++;
    edges[edge].flow=0;
    edges[edge].cost=-c;
    edges[edge].to=u;
    edges[edge].next=head[v];
    head[v]=edge++;
}

bool spfa()
{
    int i,u,v,l,r=0,tmp;
    for (i=0; i<node; i++) dis[i]=oo;
    dis[q[r++]=src]=0;
    p[src]=p[dest]=-1;
    for (l=0; l!=r; ((++l>=maxn)?l=0:1))
    {
        for (i=head[u=q[l]],vis[u]=false; i!=-1; i=edges[i].next)
        {
            if (edges[i].flow&&dis[v=edges[i].to]>(tmp=dis[u]+edges[i].cost))
            {
                dis[v]=tmp;
                p[v]=i^1;
                if (vis[v]) continue;
                vis[q[r++]=v]=true;
                if (r>=maxn) r=0;
            }
        }
    }
    return p[dest]>=0;
}

int spfaflow()
{
    int i,ret=0,delta;
    while (spfa())
    {
        //按记录原路返回求流量

        for (i=p[dest],delta=oo; i>=0; i=p[edges[i].to])
        {
            delta=min(delta,edges[i^1].flow);
        }
        for (int i=p[dest]; i>=0; i=p[edges[i].to])
        {
            edges[i].flow+=delta;
            edges[i^1].flow-=delta;
        }
        ret+=delta*dis[dest];
    }
    return ret;
}

时间: 2024-12-03 08:13:18

费用流模板的相关文章

HDU1532&amp;#160;最大流-模板题

题目是网络流-最大流的模板题 这里作为学习,把<指南>上Dinic的模板用了一下,代码如下: #include <stdio.h> #include <iostream> #include <queue> #include <string.h> #include <vector> using namespace std; const int MAXN = 10000; const int INF = 0x3f3f3f3f; int m

poj3422 Kaka&#039;s Matrix Travels(最小费用最大流问题)

/* poj3422 Kaka's Matrix Travels 不知道 k次 dp做为什么不对??? 看了大牛的代码,才知道还可以这样做! 开始没有理解将a 和 a' 之间建立怎样的两条边,导致程序一直陷入死循环,真心花了好长时间,快崩溃了.无语..... 题意:有个方阵,每个格子里都有一个非负数,从左上角走到右下角,每次走一步,只能往右或往下走,经过的数字拿走 每次都找可以拿到数字和最大的路径走,走k次,求最大和 这是 最大费用最大流 问题 每次spfa都找的是一条和最大的路径 s--到左上

最大流 二分图多重匹配问题

问题描述 最大流 二分图多重匹配问题 怎样应用最大流求解二分图多重最大匹配问题? 怎样应用最大费用流求解二分图多重最优匹配问题?

一位ACMER过来人的经验

刻苦的训练我打算最后稍微提一下.主要说后者:什么是有效地训练?        我想说下我的理解.       很多ACMer入门的时候,都被告知:要多做题,做个500多道就变牛了.其实,这既不是充分条件.也不会是必要条件.        我觉得一般情况下,对于我们普通学校的大学生,各方面能力的差距不会太大,在这种情况下,训练和学习的方法尤为重要.        其实,500题仅仅是一个标志,而且仅仅表示你做ACM-ICPC有一定的时间,        我们训练的目的是什么?我觉得有四点     

SharePoint工作流开发点滴(1)

模板(Template),关联(Association)和实例(Instance) 模板:部署到站点集中的工作流功能(Feature),用来描述该功能所包含的程序集和表单等信息. 关联:将工作流模板与列表(List)或者内容类型(Content Type)联系起来,并向工作流提供初始值或参 数.对应的表单叫做Association. 实例:在列表或内容类型项上启动的工作流.对应的表单叫做Initiation. 也就是说,实例是基于关联的,而关联又是基于模板的.一个列表或者内容类型可以拥有许多来自

浅谈对5G核心网演进方向的几点展望

最近读到一篇关于5G核心网的论文<Revolutionary Direction for 5G Mobile Core Network Architecture>,其中对于从4G到5G的演进提出了很多指导性的建议和展望,读完后感觉受益良多,于是整理其中很多有参考价值的观点并结合自己的一些体会写下这篇文章,希望对初学者有所帮助.理解不到位以及表述不清之处,欢迎批评指正. 关于4G核心网EPC的局限性,在之前的两篇文章<网络切片--5G前行的助推器>和<之于5G--浅谈SDN和N

《走进SAP(第2版)》——第1章 SAP:公司1.1 SAP的起源

第1章 SAP:公司 阅读本书,可以深入了解SAP相关产品和服务的知识.尽管后面的的章节介绍的是关于SAP应用.后台技术.支持及其对企业的好处,但是每个产品都离不开它的创建者,这对于SAP来说尤其如此.SAP的起源.成长和经营理念对它的产品以及它的用户如何从产品中受益有着重大影响. 让我们先从SAP.SAP公司以及它的历史开始,了解如何与SAP进行成功的互动. 1.1 SAP的起源 走进SAP(第2版) 概述和历史 SAP是于1972年由5位IBM的员工独立创业后建立的.5位创始人(Dietma

最小费用最大流-poj-2135

Farm Tour   Description When FJ's friends visit him on the farm, he likes to show them around. His farm comprises N (1 <= N <= 1000) fields numbered 1..N, the first of which contains his house and the Nth of which contains the big barn. A total M (1

各位大侠,请问java POI能实现用流文件读写方式拷贝一个模板excel的图片到另外一个excel中吗?

问题描述 如题,请问javaPOI能实现用流文件读写方式拷贝一个模板excel的图片到另外一个excel中吗?还有一个问题,就是POI能否流文件读写excel中插入的自定义图形,如下图所示