题目:https://www.luogu.org/problemnew/show/P4014

最大/小费用最大流裸题。

代码如下:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
using namespace std;
queue<int>q;
int const inf=1e9;
int n,t,head[],ct=,pre[],mx,mn,incf[],dis[];
bool vis[];
struct N{
int hd,to,next,w,v;
N(int h=,int t=,int n=,int w=,int v=):hd(h),to(t),next(n),w(w),v(v) {}
}edge[],tmp[];
bool spfa()
{
memset(dis,-,sizeof dis);
memset(incf,0x3f,sizeof incf);
memset(vis,,sizeof vis);
memset(pre,,sizeof pre);
while(q.size())q.pop();
dis[]=;vis[]=;q.push();
while(q.size())
{
int x=q.front();q.pop();vis[x]=;
for(int i=head[x];i;i=edge[i].next)
{
int u=edge[i].to;
if(dis[u]<dis[x]+edge[i].w&&edge[i].v)
{
dis[u]=dis[x]+edge[i].w;
pre[u]=i;
incf[u]=min(incf[x],edge[i].v);
if(!vis[u])vis[u]=,q.push(u);
}
}
}
return pre[t];
}
bool spfa2()
{
memset(dis,0x3f,sizeof dis);
memset(incf,0x3f,sizeof incf);
memset(vis,,sizeof vis);
memset(pre,,sizeof pre);
while(q.size())q.pop();
dis[]=;vis[]=;q.push();
while(q.size())
{
int x=q.front();q.pop();vis[x]=;
for(int i=head[x];i;i=tmp[i].next)
{
int u=edge[i].to;
if(dis[u]>dis[x]+tmp[i].w&&tmp[i].v)
{
dis[u]=dis[x]+tmp[i].w;
pre[u]=i;
incf[u]=min(incf[x],tmp[i].v);
if(!vis[u])vis[u]=,q.push(u);
}
}
}
return pre[t];
}
void mcf()
{
memcpy(tmp,edge,sizeof edge);
while(spfa())
{
mx+=incf[t]*dis[t];
for(int i=pre[t];i;i=pre[edge[i].hd])
{
edge[i].v-=incf[t];
edge[i^].v+=incf[t];
}
}
while(spfa2())
{
mn+=incf[t]*dis[t];
for(int i=pre[t];i;i=pre[edge[i].hd])
{
tmp[i].v-=incf[t];
tmp[i^].v+=incf[t];
}
}
}
int main()
{
scanf("%d",&n);
t=*n+;
for(int i=;i<=n;i++)
{
edge[++ct]=(N){,i,head[],,};head[]=ct;
edge[++ct]=(N){i,,head[i],,};head[i]=ct;
}
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)
{
int x;
scanf("%d",&x);
edge[++ct]=(N){i,j+n,head[i],x,};head[i]=ct;
edge[++ct]=(N){j+n,i,head[j+n],-x,};head[j+n]=ct;
}
for(int j=;j<=n;j++)
{
edge[++ct]=(N){j+n,t,head[j+n],,};head[j+n]=ct;
edge[++ct]=(N){t,j+n,head[t],,};head[t]=ct;
}
mcf();
printf("%d\n%d",mn,mx);
return ;
}

洛谷P4014分配问题——网络流24题的更多相关文章

  1. 洛谷P4011 【网络流24题】 孤岛营救问题 (BFS+状压)

    一道妙题啊......(不知道为什么这道题的标签是网络流,不需要用网络流啊) 如果没有门和钥匙,连边(边权为1)求最短路就行了. 但是有这两个因素的限制,我们采用分层建图的思想,一共2p层,每层对应持 ...

  2. 洛谷P4015 运输问题 网络流24题

    看了下SPFA题解,一个一个太麻烦了,另一个写的很不清楚,而且注释都变成了"????"不知道怎么过的,于是自己来一发SPFA算法. Part 1.题意 M 个仓库,卖给 N 个商店 ...

  3. 洛谷P4014 分配问题【最小/大费用流】题解+AC代码

    洛谷P4014 分配问题[最小/大费用流]题解+AC代码 题目描述 有 n 件工作要分配给 n 个人做.第 i 个人做第 j 件工作产生的效益为c ij. 试设计一个将 n 件工作分配给 n 个人做的 ...

  4. 洛谷——P4014 分配问题

    P4014 分配问题 题目描述 有 nn 件工作要分配给 nn 个人做.第 ii 个人做第 jj 件工作产生的效益为 c_{ij}cij​ .试设计一个将 nn 件工作分配给 nn 个人做的分配方案, ...

  5. Luogu P4014 「 网络流 24 题 」分配问题

    解题思路 还是建立超级源点和超级汇点,又因为题目给出规定一个人只能修一个工件,所以建图的时候还要讲容量都设为$1$. 人的编号是$1\rightarrow n$,工件的编号是$n+1\rightarr ...

  6. 洛谷P4014 分配问题(费用流)

    传送门 可以把原图看做一个二分图,人在左边,任务在右边,求一个带权的最大和最小完美匹配 然而我并不会二分图做法,所以只好直接用费用流套进去,求一个最小费用最大流和最大费用最大流即可 //minamot ...

  7. 洛谷 P4014 分配问题 【最小费用最大流+最大费用最大流】

    其实KM更快--但是这道题不卡,所以用了简单粗暴的费用流,建图非常简单,s向所有人连流量为1费用为0的边来限制流量,所有工作向t连流量为1费用为0的边,然后对应的人和工作连(i,j,1,cij),跑一 ...

  8. 洛谷P4014 分配问题(费用流)

    题目描述 有 nn 件工作要分配给 nn 个人做.第 ii 个人做第 jj 件工作产生的效益为 c_{ij}cij​ .试设计一个将 nn 件工作分配给 nn 个人做的分配方案,使产生的总效益最大. ...

  9. 洛谷P4009汽车加油行驶问题——网络流24题(最短路)

    题目:https://www.luogu.org/problemnew/show/P4009 网络流24题中不是网络流的最短路题: 把每个点拆成各个油量上的点,根据要求连边即可: 注意:点数最大为10 ...

随机推荐

  1. python 工具 二进制文件处理之——去掉指定长度数据包头

    包头48bit 数据98464 ...如此循环: piece_size = 48 piece_size1 = 98464 with open("C:\\Users\\Administrato ...

  2. install nfs and share file

    介绍一下NFS的安装,以及共享文件 NFS(Net File System),通过使用NFS,可以像使用本地文件一样访问远程文件. 它主要解决了数据共享的问题,可以备份容灾. 安装配置 1.以linu ...

  3. 怎样用命令行管理SharePoint Feature?

    普通情况下对IT管理者来说.在SharePoint Farm中维护Feature,更喜欢使用命令行实现,这样能够省去登录到详细网站的操作. 比方IT接到end user的一个需求,要开启Site Co ...

  4. PS 如何制作WIN7的玻璃化透明窗口效果

    1 绘制一个圆角矩形,并将不透明度设为16%以及添加投影效果   2 再次添加外发光效果   3 新建一个图层,再填充一下这个圆角矩形(可以填充为任意颜色,只要和别的颜色区分开来)   4 选中这个区 ...

  5. logstash+es+kibana+redis搭建

    环境信息: CentOS 6.5 redis 3.0.4 logstash elasticsearch kibana 服务端ip:192.168.0.65 客户端ip:192.168.0.66 关系结 ...

  6. C#设计模式总结 C#设计模式(22)——访问者模式(Vistor Pattern) C#设计模式总结 .NET Core launch.json 简介 利用Bootstrap Paginator插件和knockout.js完成分页功能 图片在线裁剪和图片上传总结 循序渐进学.Net Core Web Api开发系列【2】:利用Swagger调试WebApi

    C#设计模式总结 一. 设计原则 使用设计模式的根本原因是适应变化,提高代码复用率,使软件更具有可维护性和可扩展性.并且,在进行设计的时候,也需要遵循以下几个原则:单一职责原则.开放封闭原则.里氏代替 ...

  7. EasyUI基础入门之Droppable(可投掷)

    怎么说呢Droppable这个单词究竟是什么意思,准确来说easyui作者究竟要表达什么意思,还是不大好拿捏的.只是没关系,没有必要纠结与这些细枝末节的东西,依据官网的demo效果,就简单的将之定义为 ...

  8. XML(四)dom4j解析XML

    使用dom4j须要导入jar包 jar包下载地址:http://pan.baidu.com/s/1o65jWRw 将dom4j-1.6.1.jar包导入Eclipse book2.xml <?x ...

  9. css-装饰

    css -在标签上设置style样式 background-color:#2356a1 height:48px -编写样式方法 1.标签的style属性 2.鞋子head里面,style标签中编写 - ...

  10. FALSE_IT

    本文讲一个实用的语法糖(suger),很不错,攻克了我实际工作中的问题. 如果你写了这样一个类: class Executor { int step1(); void step2(); int ste ...