P4014 分配问题

题目描述

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

输入输出格式

输入格式:

文件的第 11 行有 11 个正整数 nn,表示有 nn 件工作要分配给 nn 个人做。

接下来的 nn 行中,每行有 nn 个整数 c_{ij}cij​​​,表示第 ii 个人做第 jj 件工作产生的效益为 c_{ij}cij​。

输出格式:

两行分别输出最小总效益和最大总效益。

输入输出样例

输入样例#1: 复制

5
2 2 2 1 2
2 3 1 2 4
2 0 1 1 1
2 3 4 3 3
3 2 1 2 1
输出样例#1: 复制

5
14

说明

1 \leq n \leq 1001≤n≤100

一个人只能修一个工件

解题报告:

如何建图?

最小收益:建立一个超级源点S和超级汇点T,超级源点向每个工人连边,容量为1,费用为0,表示限制每个人只能有一种工作;  

每个工人向每个工作连边,容量为1,费用为0,这样当这条边有流时 ,费用即为收益;

每个工作向超级汇点连边 ,容量为1,费用为0 ,表示限制每个工作只能被做一次;

跑完最大流后收益即为最小收益。

最大收益,即最大费用流 ,将原图中的边的费用全部取反 ,然后跑费用流 ,最后费用取反即可

我的代码自带大常数QWQ

#include<iostream>
#include<cstdio>
#include<queue>
#include<cstring> #define N 1010100
using namespace std; int n,m,S,T,head[N],tot;
struct node{
int to,next,flow,w;
}e[N]; int dis[N],flow[N],pre[N],last[N],cost;
bool vis[N]; queue<int>Q;
struct MCMFF{
void init(){
tot=-,cost=;
memset(head,-,sizeof(head));
memset(e,,sizeof(e));
}
void add(int u,int v,int flow,int w){
e[++tot].to=v,e[tot].next=head[u],head[u]=tot,e[tot].w=w,e[tot].flow=flow;
}
void Add(int u,int v,int flow,int w){
add(u,v,flow,w);
add(v,u,,-w);
}
bool spfa()
{
memset(vis,,sizeof(vis));
memset(dis,0x7f,sizeof(dis));
memset(flow,0x7f,sizeof(flow));
Q.push(S);vis[S]=,pre[T]=-,dis[S]=;
while(!Q.empty()){
int u=Q.front();Q.pop();
vis[u]=;
for(int i=head[u];i!=-;i=e[i].next){
int v=e[i].to;
if(e[i].flow>&&dis[v]>dis[u]+e[i].w){
dis[v]=dis[u]+e[i].w;
pre[v]=u,last[v]=i;
flow[v]=min(flow[v],e[i].flow);
if(!vis[v]){
Q.push(v);
vis[v]=;
}
}
}
}return pre[T]!=-;
}
void MCMF(){
while(spfa()){
int u=T;
cost+=flow[T]*dis[T];
while(u!=S){
e[last[u]].flow-=flow[T];
e[last[u]^].flow+=flow[T];
u=pre[u];
}
}
}
}netfl; int work[][]; int main()
{
scanf("%d",&n);
netfl.init();
S=,T=*n+;
for(int i=;i<=n;i++){
netfl.Add(S,i,,);
netfl.Add(i+n,T,,);
for(int j=;j<=n;j++){
scanf("%d",&work[i][j]);
netfl.Add(i,j+n,,work[i][j]);
}
}
netfl.MCMF();
printf("%d\n",cost);
netfl.init();
for(int i=;i<=n;i++){
netfl.Add(S,i,,);
netfl.Add(i+n,T,,);
for(int j=;j<=n;j++){
netfl.Add(i,j+n,,-*work[i][j]);
}
}
netfl.MCMF();
printf("%d\n",-*cost);
return ;
}

洛谷——P4014 分配问题的更多相关文章

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

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

  2. 洛谷P4014分配问题——网络流24题

    题目:https://www.luogu.org/problemnew/show/P4014 最大/小费用最大流裸题. 代码如下: #include<iostream> #include& ...

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

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

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

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

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

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

  6. 洛谷 P4016负载平衡问题【费用流】题解+AC代码

    洛谷 P4016负载平衡问题 P4014 分配问题[费用流]题解+AC代码 负载平衡问题 题目描述 GG 公司有n个沿铁路运输线环形排列的仓库,每个仓库存储的货物数量不等.如何用最少搬运量可以使 n ...

  7. 洛谷P1402 酒店之王(网络流)

    ### 洛谷P1402 题目链接 ### 题目大意:有 n 个人, p 间房间,q 种食物.每个人喜欢一些房间,一些食物,但每间房间.每种食物只能分配给一个人.问最大可以让多少个人满足(当且仅当分配到 ...

  8. 洛谷1640 bzoj1854游戏 匈牙利就是又短又快

    bzoj炸了,靠离线版题目做了两道(过过样例什么的还是轻松的)但是交不了,正巧洛谷有个"大牛分站",就转回洛谷做题了 水题先行,一道傻逼匈牙利 其实本来的思路是搜索然后发现写出来类 ...

  9. 洛谷P1352 codevs1380 没有上司的舞会——S.B.S.

    没有上司的舞会  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond       题目描述 Description Ural大学有N个职员,编号为1~N.他们有 ...

随机推荐

  1. UVA 23 out of 5

    题目例如以下: Problem I 23 Out of 5 Input: standard input Output: standardoutput Time Limit: 1 second Memo ...

  2. [Sqlite]--&gt;数据迁移备份--从低版本号3.6.2到高版本号3.8.6

    引子: 1. Sqlite在Windows.Linux 和 Mac OS X 上的安装过程 2.嵌入式数据库的安装.建库.建表.更新表结构以及数据导入导出等等具体过程记录 个字段IPHONE和LOGI ...

  3. There was a conflict between

    解读,首先搜索到第一个5>的开头的那一行,确认是在编译哪一个项目. 那么后面的冲突,就是在和这个项目冲突. There was a conflict between "log4net, ...

  4. ASP.NET SignalR Hubs API Guide - JavaScript Client

    https://docs.microsoft.com/en-us/aspnet/signalr/overview/guide-to-the-api/hubs-api-guide-javascript- ...

  5. 【HAOI 2008】 糖果传递

    [题目链接] https://www.lydsy.com/JudgeOnline/problem.php?id=1045 [算法] 环形均分纸牌问题 [代码] #include<bits/std ...

  6. (函数即服务)Faas的现状与未来

    刚看到jolestar一位从法律转行程序员的前辈写了一篇Faas现状与未来的文章,里面很多观点都很有启发,或许正如他说的那样,由于Faas能较好的解决资源利用率和开发效率问题,2018年Faas将变得 ...

  7. PCB SQL SERVER 字段模糊匹配个数 实现方法

    今天工程系统给到加投加投组件的数据规则修改,遇到需将一个字段模糊匹配的个数统计 这类需求要平时应该很少遇到了,这里将此方法分享出来, 一.需求如下 例子:itempara字段中的内容是: IVH板 铜 ...

  8. U3D版本控制设置 Force Text优劣

    git的忽略列表 .gitignore Library/ Temp/ .vs/ *.csproj *.sln Edit > Project Settings > Editor 下把meta ...

  9. $ST表刷题记录$

    \(st表的题目不太多\) 我做过的就这些吧. https://www.luogu.org/problemnew/show/P3865 https://www.luogu.org/problemnew ...

  10. 服务器上oracle的监听设置

    1.查看本机的计算机名 2.修改etc/host 3.修改oracle的listener.ora(我服务器上的路径:) 4.修改tnsnames.ora(和上边文件一个目录)