题目大意:

传送门

题解:

很容易建模,把每一个工作人员拆成两个点,由第一个点向第二个点连S+1条边即可。

这水题没什么难度,主要是longlong卡的丧心病狂。。。

代码

#include <bits/stdc++.h>
#define ll long long
using namespace std;
const ll maxn = 2550;
const ll maxv = maxn * 10;
const ll inf = 1000000000000;
ll dist[maxv], inq[maxv], pree[maxv], fl[maxv];
struct edge {
ll from;
ll to;
ll cap;
ll cost;
};
vector<edge> edges;
vector<ll> G[maxv];
ll n, m, a[maxn][maxn], c[maxn], v;
void add_edge(ll from, ll to, ll cap, ll cost) {
edges.push_back((edge){from, to, cap, cost});
edges.push_back((edge){to, from, 0, -cost});
ll m = edges.size();
G[from].push_back(m - 2);
G[to].push_back(m - 1);
}
bool spfa(ll s, ll t, ll &cost) {
for (int i = 0; i < v; i++)
dist[i] = inf;
memset(inq, 0, sizeof(inq));
memset(pree, 0, sizeof(pree));
memset(fl, 0, sizeof(fl));
queue<ll> q;
fl[s] = inf;
dist[s] = 0, inq[s] = 1;
q.push(s);
while (!q.empty()) {
ll 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 > 0 && dist[e.to] > dist[u] + e.cost) {
dist[e.to] = dist[u] + e.cost;
pree[e.to] = G[u][i];
fl[e.to] = min(fl[u], e.cap);
if (!inq[e.to]) {
q.push(e.to);
inq[e.to] = 1;
}
}
}
}
if (dist[t] >= inf)
return false;
ll flow = fl[t];
cost += flow * dist[t];
ll u = t;
while (!u == s) {
edges[pree[u]].cap -= flow;
edges[pree[u] ^ 1].cap += flow;
u = edges[pree[u]].from;
}
return true;
}
ll mcmf(int s, int t) {
ll cost = 0;
while (spfa(s, t, cost))
;
return cost;
}
void solve() {
// 1-m:员工
// m+1~m+n 产品
// m+n+1~m+n+m 拆点后的员工
scanf("%lld %lld", &m, &n);
ll s = 0, t = n + m + m + 1;
v = t + 1; for (int i = 1; i <= n; i++) {
scanf("%lld", &c[i]);
add_edge(m + i, t, c[i], 0);
}
for (int i = 1; i <= m; i++)
for (int j = 1; j <= n; j++) {
int x;
scanf("%d", &x);
if (x)
add_edge(i, j + m, inf, 0);
}
for (int i = 1; i <= m; i++) {
add_edge(s, n + m + i, inf, 0);
ll s;
scanf("%lld", &s);
ll T[maxn];
T[0] = 0;
for (int j = 1; j <= s; j++)
scanf("%lld", &T[j]);
for (int j = 1; j <= s; j++) {
ll y;
scanf("%lld", &y);
add_edge(n + m + i, i, T[j] - T[j - 1], y);
}
scanf("%lld", &s);
add_edge(n + m + i, i, inf, s);
}
ll ans = mcmf(s, t);
printf("%lld\n", ans);
}
int main() {
// freopen("input", "r", stdin);
solve();
}

[bzoj2245][SDOI2011]工作安排——费用流的更多相关文章

  1. BZOJ 2245: [SDOI2011]工作安排( 费用流 )

    费用流模板题..限制一下不同愤怒值的工作数就可以了. ------------------------------------------------------------------------- ...

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

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

  3. P2488 [SDOI2011]工作安排 费用流

    \(\color{#0066ff}{ 题目描述 }\) 你的任务是制定出一个产品的分配方案,使得订单条件被满足,并且所有员工的愤怒值之和最小.由于我们并不想使用Special Judge,也为了使选手 ...

  4. [bzoj2245][SDOI2011]工作安排(费用流)

    题目:http://www.lydsy.com:808/JudgeOnline/problem.php?id=2245 分析: 要注意到题目下面说的w是单增的 明显的费用流: 弄个源点S,汇点T S连 ...

  5. bzoj2245: [SDOI2011]工作安排

    费用流. 这道题的模型比较明显,拆点也是很容易看出来的. #include<cstdio> #include<algorithm> #include<cstring> ...

  6. BZOJ 2245 SDOI 2011 工作安排 费用流

    题目大意:有一些商品须要被制造.有一些员工.每个员工会做一些物品,然而这些员工做物品越多,他们的愤慨值越大,这满足一个分段函数.给出哪些员工能够做哪些东西,给出这些分段函数,求最小的愤慨值以满足须要被 ...

  7. BZOJ2245 [SDOI2011]工作安排 【费用流】

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

  8. 【BZOJ2245】[SDOI2011]工作安排(费用流)

    [BZOJ2245][SDOI2011]工作安排(费用流) 题面 BZOJ 洛谷 题解 裸的费用流吧. 不需要拆点,只需要连边就好了,保证了\(W_j<W_{j+1}\). #include&l ...

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

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

随机推荐

  1. #Python编程从入门到实践#第四章笔记

    #Python编程从入门到实践#第四章笔记   操作列表 ​​​1.遍历列表 使用for循环,遍历values列表 for value in values: print(value) 2.数字列表 使 ...

  2. PLY手册翻译

    https://www.kancloud.cn/kancloud/ply/42143 http://wiki.jikexueyuan.com/project/python-lex-yacc/ply-0 ...

  3. Python的输入和输出问题详解

    输出用print()在括号中加上字符串,就可以向屏幕上输出指定的文字.比如输出'hello, world',用代码实现如下: >>> print('hello, world') pr ...

  4. Robots Gym - 101915G

    传送门 The Robotics Olympiad teams were competing in a contest. There was a tree drawn on the floor, co ...

  5. C++ 二叉搜索树

    二叉搜索树利用其特有的二叉树性质,使其搜索更方便 源代码: struct node { int val; node *left, *right; }; //the function of insert ...

  6. CodeForces 785E Anton and Permutation 分块

    题意: 有一个\(1 \sim n\)的排列\(A\),有\(q\)个询问: 交换任意两个元素的位置,求交换之后排列的逆序数 分析: 像这种不太容易用线段树,树状数组维护的可以考虑分块 每\(\sqr ...

  7. compileReleaseJavaWithJavac

    如果你打release 包的时候,出现这个问题,那么请你先跑一下程序,肯定是有什么方法名,或者什么东西没找到. release 的时候不会报错,只有你跑的时候才会报错.

  8. 《Cracking the Coding Interview》——第18章:难题——题目8

    2014-04-29 03:10 题目:给定一个长字符串S和一个词典T,进行多模式匹配,统计S中T单词出现的总个数. 解法:这是要考察面试者能不能写个AC自动机吗?对面试题来说太难了吧?我不会,所以只 ...

  9. shell脚本递归删除空文件夹

    有时我们需要递归删除空文件夹,网上找了一下,没有发现比较好的脚本,于是自己动手写了一个 脚本 #!/bin/bash # author: 十年后的卢哥哥(http://www.cnblogs.com/ ...

  10. save?commit

    数据库的隐式提交 先看一段SQL,最后一条SQL的输出你认为是什么? 1 2 3 4 5 6 7 SET AUTOCOMMIT = 1; BEGIN; INSERT INTO t1 VALUES (1 ...