题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=693

题意:有一个 k 核的处理器和 n 个工作,全部的工作都须要在一个核上处理一个单位的时间,每一个核在不同一时候间处理同一个工作的花费是递增的,每一个核一次仅仅能处理一个工作,求运用k个核处理这n个工作的最小花费。

分析:

分析可知,求处理全部工作的最小花费,而每次选择怎么处理我们能够通过容量都为1的边来让网络流处理,这样就转化为最小费用最大流。

首先设一个超级源点s,连接全部的工作,流量1,花费0,然后每一个工作建一个边连接每一个工作不同一时候间处理的花费,流量为1,花费为花费,然后每一个时间段在连接汇点,流

量为k( 由于在单位1的时间里有k个核在处理k个工作 ),花费为0,然后套模板求一个从 s 到 t 的最小费用最大流。

有一个优化就是发现每一个工作不同一时候间处理的花费是递增的,那么每一个核肯定每次是选择在 n/k+1前 的时间处理,所以之后的边能够直接不建边,节省时间。(经測试发现这个题目没有这一步优化会超时)

代码:

#include<iostream>
#include<string>
#include<algorithm>
#include<cstdlib>
#include<cstdio>
#include<set>
#include<map>
#include<vector>
#include<cstring>
#include<stack>
#include<cmath>
#include<queue>
using namespace std;
#define CL(x,v); memset(x,v,sizeof(x));
#define INF 0x3f3f3f3f
#define LL long long
#define REP(i,r,n) for(int i=r;i<=n;i++)
#define RREP(i,n,r) for(int i=n;i>=r;i--)
const int MAXN=222222;
struct Edge{int from,to,cap,flow,cost;
};
struct MCMF{int n,m,s,t;vector<Edge>edges;vector<int> G[MAXN];int inq[MAXN];int d[MAXN];int p[MAXN];int a[MAXN];void init(int n){this->n=n;for(int i=0;i<=n;i++)G[i].clear();edges.clear();}void AddEdge(int from,int to,int cap,int cost){  //建边edges.push_back((Edge){from,to,cap,0,cost});edges.push_back((Edge){to,from,0,0,-cost});m=edges.size();G[from].push_back(m-2);G[to].push_back(m-1);}bool BellmanFord(int s,int t,int& flow,int& cost){  //最短路增光for(int i=0;i<=n;i++)d[i]=INF;CL(inq,0);d[s]=0;inq[s]=1;p[s]=0;a[s]=INF;queue<int>Q;Q.push(s);while(!Q.empty()){int u=Q.front();Q.pop();inq[u]=0;for(int i=0;i<G[u].size();i++){Edge& e=edges[G[u][i]];if(e.cap>e.flow&&d[e.to]>d[u]+e.cost){d[e.to]=d[u]+e.cost;p[e.to]=G[u][i];a[e.to]=min(a[u],e.cap-e.flow);if(!inq[e.to]){Q.push(e.to);inq[e.to]=1;}}}}if(d[t]==INF)return false;flow+=a[t];cost+=d[t]*a[t];int u=t;while(u!=s){edges[p[u]].flow+=a[t];edges[p[u]^1].flow-=a[t];u=edges[p[u]].from;}return true;}int Mincost(int s,int t){  ///求费用int flow=0,cost=0;while(BellmanFord(s,t,flow,cost));return cost;}
};int n,m,k;
MCMF solver;
int main()
{int T;scanf("%d",&T);while(T--){int core,work,x;scanf("%d%d",&core,&work);int tmp=work/core+1;solver.init(work*2+2);for(int i=1;i<=work;i++){solver.AddEdge(0,i,1,0);for(int j=1;j<=work;j++){scanf("%d",&x);if(j<=tmp)solver.AddEdge(i,j+work,1,x);}}for (int i=1;i<=work;i++){if (i<=tmp)solver.AddEdge(i+work,work*2+1,core,0);}int s=0,t=work*2+1;int ans=solver.Mincost(s,t);printf("%d\n",ans);}return 0;
}

Doctor NiGONiGO’s multi-core CPU(最小费用最大流模板)相关推荐

  1. 费用流:最大费用最大流和最小费用最大流(模板)

    主要是思维建边,建有向边,然后跑模板就行了 可以解决KM算法所能解决的问题(完全取代) 可以解决非完备匹配问题中的最大权匹配和最小权匹配,分别对应着最大费用最大流和最小费用最大流 模板: 最大费用最大 ...

  2. 最大流 最小费用最大流模板

    模板从  这里   搬运,链接博客还有很多网络流题集题解参考. 最大流模板 ( 可处理重边 ) const int maxn = 1e6 + 10; const int INF = 0x3f3f3f3 ...

  3. 乌鲁木齐网络赛J题(最小费用最大流模板)

    ACM ICPC 乌鲁木齐网络赛 J. Our Journey of Dalian Ends 2017-09-09 17:24 243人阅读 评论(0) 收藏 举报  分类: 网络流(33)  版权声 ...

  4. 【最小费用可行流模板】

    可能再也用不到了吧,今天整理电脑文件看到的,作为图论选手,留个纪念, //原图: 对于pi,拆点xi,yi s->S,[m,m],0 S->xi,[0,inf],0 yi->t,[0 ...

  5. POJ-3469 Dual Core CPU 最小割最大流

    该题是给定对个任务,然后告诉你这多个任务在两个不同的核心上执行任务所花费的不同代价,并且还告诉如果其中一些任务不在同一个核心上面运行的话,还有有多余的开销.最后问我们完成所有任务的最小开销是多少? 对 ...

  6. POJ 2195 Going Home / HDU 1533(最小费用最大流模板)

    题目大意: 有一个最大是100 * 100 的网格图,上面有 s 个 房子和人,人每移动一个格子花费1的代价,求最小代价让所有的人都进入一个房子.每个房子只能进入一个人. 算法讨论: 注意是KM 和 ...

  7. 有源汇上下界最小费用可行流 ---- P4043 [AHOI2014/JSOI2014]支线剧情(模板)

    题目链接 题目大意: 解题思路: 有源汇上下界最小费用可行流模板题目来着 先建出一个有源汇上下界可行流的图,然后注意建图的时候要把每条边的下界的费用提前加到ans里面 然后再对图跑费用流,就是补齐费用 ...

  8. 网络流之——最小费用最大流

    学习最小费用最大流前,需要学习最大流算法.在最大流算法中,没有考虑边的费用问题.在MinCostMaxFlow中,引入了费用的概念:cij表示边(i,j)单位流量的费用.在满足流量=v(f)的同时,并 ...

  9. HDU 1853 HDU 3488【有向环最小权值覆盖问题 】最小费用最大流

    HDU 1853 & HDU 3488[有向环最小权值覆盖问题 ]带权二分图匹配 KM算法 In the kingdom of Henryy, there are N (2 <= N & ...

最新文章

  1. PROC简单使用用例--VC连接ORACLE
  2. mysql ddl crash,MySQL5.6 crash-safe replication一个坑
  3. c 语言程序设计现代方法:13章习题自己编答案(持续更新)
  4. java接口经常变动前端怎么办_Java进程故障排查(CPU资源占用高,接口响应超时,功能接口停滞等)...
  5. qmap不能作为信号与槽的传递_撩妹 | 女生对你有好感的三个信号,千万别错过了...
  6. Visual Studio 插件的开发
  7. zookeeper简单命令
  8. 2017计算机基础知识ppt,2017计算机基础试卷.doc
  9. MCS51单片机的输入/输出接口
  10. antd的timePicker.RangePicker设置结束时间不可早于开始时间
  11. java读取json文件
  12. amaze 绝对位置 html,amaze ui 的使用详细教程
  13. 2022最新个人所得税计算(附代码)
  14. 2022 IDLE 配置
  15. pg_auto_failover 之四 manual failover
  16. Android模拟器运行MIUI,电脑上玩小米枪战吃鸡手游 逍遥安卓模拟器设置教程
  17. Excel VBA(04)数组和字典
  18. 1067 mysql_mysql服务1067错误多种解决方案分享
  19. 大数据相关书籍(包含Java, Scala, R, Linux, Spark, Hadoop, Hive, Hbase, Sqoop, Flume, Strom)
  20. Element-UI可编辑表格的实现

热门文章

  1. Python-memcached的基本使用
  2. 生活问题 | 对华为畅玩手机5X进行升级
  3. squid缓存服务器
  4. VUE中使用sass
  5. 从传统运维到云运维演进历程之软件定义存储(五)上
  6. IIS PHP 配置 问题总结
  7. mint 15用fcitx框架安装中文谷歌输入法
  8. WINDOWS SERVER 2003从入门到精通之“域控制器安全策略”打开错误的解决方法
  9. ASP.NET中随机数生成及应用
  10. [Jobdu] 题目1504:把数组排成最小的数