题目链接

【分析】

先吐槽:题目读的真的烦。。刚开始理解错了题意算出来答案怎么都不对还不知道哪里错了。。中午回家才想出来。。真的是勺的掺。

其实这个题还是很裸的费用流。。看懂题就好。

【建图】

  1. S向每个产品建边,流量为Ci,费用为0.
  2. 每个员工向T建Si+1条边,流量为t[i][j]-t[i][j-1],费用为w[i][j]。为了方便,可以直接将t[i][si+1]赋为INF。
  3. 有关系的产品和员工之间建边,流量为INF,费用为0.

(不开long long一分都没有,这样真的好吗!!?)

【代码】

#include <cstdio>
#include <iostream>
#include <queue>
#include <vector>
#include <algorithm>
#include <cstring>
#include <cmath>
#include <stack>
#define N 505
#define M 128505
#define INF 1000000000
using namespace std;
typedef long long ll;
typedef pair<ll,ll> pa;int read()
{int x=0,f=1;char ch=getchar();while(!isdigit(ch)){if(ch=='-') f=-1;ch=getchar();}while(isdigit(ch)){x=x*10+ch-'0';ch=getchar();}return x*f;
}ll ans;
int n,m,cnt=1,S,T;
int b[M],p[N],nextedge[M],w[M],c[M];
int Dis[N],Pre[N],a[255][255],t[255],val[255];
bool Flag[N];void Add(int x,int y,int z,int cost)
{cnt++;b[cnt]=y;nextedge[cnt]=p[x];p[x]=cnt;w[cnt]=z;c[cnt]=cost;
}void Anode(int x,int y,int z,int cost){Add(x,y,z,cost);Add(y,x,0,-cost);
}void Input_Init()
{m=read(),n=read();T=n+m+1;static int x,num;for(int i=1;i<=n;i++){x=read();Anode(0,i,x,0);}for(int i=1;i<=m;i++)for(int j=1;j<=n;j++){x=read();if(x) Anode(j,i+n,INF,0);}for(int i=1;i<=m;i++){num=read();for(int j=1;j<=num;j++) t[j]=read();t[num+1]=INF;for(int j=1;j<=num+1;j++)Anode(i+n,T,t[j]-t[j-1],read());}
}bool Bfs()
{queue<int>q;q.push(S);for(int i=1;i<=T;i++) Dis[i]=INF;while(!q.empty()){int k=q.front();q.pop();Flag[k]=0;for(int i=p[k];i;i=nextedge[i]){int v=b[i],f=w[i];if(Dis[v]>Dis[k]+c[i]&&f){Dis[v]=Dis[k]+c[i];Pre[v]=i;if(!Flag[v]){Flag[v]=1;q.push(v);}}}}return Dis[T]!=INF;
}void Mcf()
{int Maxf=INF;for(int i=Pre[T];i;i=Pre[b[i^1]])Maxf=min(Maxf,w[i]);for(int i=Pre[T];i;i=Pre[b[i^1]]){w[i]-=Maxf;w[i^1]+=Maxf;ans+=(ll)Maxf*(ll)c[i];}
}void MCF()
{while(Bfs())Mcf();printf("%lld\n",ans);
}int main()
{Input_Init();MCF();return 0;
}

BZOJ2245: [SDOI2011]工作安排相关推荐

  1. bzoj2245 [SDOI2011]工作安排

    (http://www.elijahqi.win/2017/12/11/bzoj2245-sdoi2011%E5%B7%A5%E4%BD%9C%E5%AE%89%E6%8E%92/%20%E2%80% ...

  2. bzoj2245 [SDOI2011]工作安排 费用流

    注意这里的分段函数只和个数有关,与种类无关, 然后直接建图,注意开long long 码: #include<iostream> #include<cstdio> #inclu ...

  3. 【BZOJ2245】[SDOI2011]工作安排 拆边费用流

    [BZOJ2245][SDOI2011]工作安排 Description 你的公司接到了一批订单.订单要求你的公司提供n类产品,产品被编号为1~n,其中第i类产品共需要Ci件.公司共有m名员工,员工被 ...

  4. 【bzoj2245】[SDOI2011]工作安排 费用流

    题目描述 你的公司接到了一批订单.订单要求你的公司提供n类产品,产品被编号为1~n,其中第i类产品共需要Ci件.公司共有m名员工,员工被编号为1~m员工能够制造的产品种类有所区别.一件产品必须完整地由 ...

  5. [SDOI2011]工作安排 BZOJ2245

    分析: 费用流裸题,按照题面要求建边就可以了,语文题,我读了10多分钟才知道这题干啥...特别是注意一个细节a[j+1]-a[j]... 附上代码: #include <cstdio> # ...

  6. bzoj 2245 [SDOI2011]工作安排【最小费用最大流】

    其实不用拆点,对于每个人我们假装他是\( s[i]+1 \)个点,可以由他向T点分别连\( s[i]+1 \)条边,容量为\( t[i][j]-t[i][j-1]\),由S点向所有产品i连容量为c[i ...

  7. [BZOJ1572][Usaco2009 Open]工作安排Job

    1572: [Usaco2009 Open]工作安排Job Time Limit: 10 Sec  Memory Limit: 64 MB Submit: 1351  Solved: 632 [Sub ...

  8. 麦肯锡顾问深度工作安排:将工作可视化

    工作表安排的三个步骤 凡是善于工作的人,都有一个共通的方法,那就是他们能够有意识或者无意识地使自己的整体工作可视化. 商业系统型的工作安排法: 流程:为了创造价值明确工作的整体流程 分解:将整体流程分 ...

  9. 综合布线工作组2008年上半年技术课题工作安排会议通知

    中国工程建设标准化协会信息通信专业委员会   建标信通字[2008] 02号 综合布线工作组2008年上半年技术课题工作安排会议通知   各工作组成员 中国工程建设标准化协会信息通信专业委员会综合布线 ...

最新文章

  1. LOJ2586 APIO2018 选圆圈
  2. java socket同步通信,javasocket客户端与服务端同步通信实例
  3. [Effective JavaScript 笔记]第59条:避免过度的强制转换
  4. 16个经典面试问题回答思路[求职者必看]
  5. php数字导出excel表格中_php怎么把数据表中的数据导出到excel表中
  6. 点击右侧导航栏,实现iframe嵌入子页面中div,滑动到最上面
  7. matlab飞行数据仿真,基于MATLAB的飞行仿真
  8. 计算机科学与技术专业可以转哪些专业,计算机科学与技术学院本科生转专业实施细则...
  9. linux vim命令_提升生产力的20大Linux Vim命令
  10. [小技巧]为Atlas AutoComplete加上滚动条
  11. Kerio Network Monitor
  12. VMware中Linux虚拟机root密码重置
  13. Word控件Spire.Doc 转换教程(三):如何将 Word 转换为 PDF
  14. 电子邮件的地址格式是怎样的?请说明各部分的意思。
  15. HBuilderX网站打包APP
  16. SQL中的limit用法
  17. 360搜索“触链”聚焦版权领域,“图刻”是噱头还是不忘安全初心?
  18. mysql搜索斯芬克斯_如何用sphinx正确搜索数字?
  19. 数据存储(1):从数据存储看人类文明-数据存储器发展历程
  20. div在不固定高度的情况下垂直或者水平居中

热门文章

  1. R8500 MPv2 版本 刷 Kong编译的 ddwrt 后,使用Entware-ng 安装opkg安装第三方软件
  2. 关于Vue项目不报错但是不显示组件的问题(原因之一)
  3. 高通Android 12默认授权 不弹出投屏弹窗
  4. matlab/simulink/simpowersystem中连续vs离散
  5. Web3D智慧数字三维工地 HTML5+Threejs实战开发
  6. 基于SSM汽车买卖保养维护网站
  7. 【淘宝开店教程】教你借618大促打造店铺爆款宝贝
  8. mysql ERROR 1178 (42000) at line 241: The storage engine for the table doesn‘t support native partit
  9. 华科计算机考研机试真题汇总下篇(C语言)
  10. python键盘监听模块大全_python监听、操作键盘鼠标库pynput详细教程