Less Time, More profit 最大权闭合子图(最大流最小割)
Each shop needs products from some plants to make profit of proiproi units.
Building ith plant needs investment of payipayi units and it takes titi days.
Two or more plants can be built simultaneously, so that the time for building multiple plants is maximum of their periods(titi).
You should make a plan to make profit of at least L units in the shortest period.
InputFirst line contains T, a number of test cases.
For each test case, there are three integers N, M, L described above.
And there are N lines and each line contains two integers payipayi, titi(1<= i <= N).
Last there are M lines and for each line, first integer is proiproi, and there is an integer k and next k integers are index of plants which can produce material to make profit for the shop.
1 <= T <= 30
1 <= N, M <= 200
1≤L,ti≤10000000001≤L,ti≤1000000000
1≤payi,proi≤300001≤payi,proi≤30000
OutputFor each test case, first line contains a line “Case #x: t p”, x is the number of the case, t is the shortest period and p is maximum profit in t hours. You should minimize t first and then maximize p.
If this plan is impossible, you should print “Case #x: impossible”
Sample Input
- 2
- 1 1 2
- 1 5
- 3 1 1
- 1 1 3
- 1 5
- 3 1 1
Sample Output
- Case #1: 5 2
- Case #2: impossible
- #include<iostream>
- #include<cstdio>
- #include<cmath>
- #include<cstring>
- #include<sstream>
- #include<algorithm>
- #include<queue>
- #include<deque>
- #include<iomanip>
- #include<vector>
- #include<cmath>
- #include<map>
- #include<stack>
- #include<set>
- #include<fstream>
- #include<memory>
- #include<list>
- #include<string>
- using namespace std;
- typedef long long LL;
- typedef unsigned long long ULL;
- #define MAXN 405
- #define L 31
- #define INF 1000000009
- #define eps 0.00000001
- #define sf(a) scanf("%lld",&a)
- struct plant
- {
- LL pay, time;
- LL id;
- bool operator<(const plant& rhs) const
- {
- return time < rhs.time;
- }
- };
- struct shop
- {
- LL cnt, time, pro;
- LL pl[MAXN];
- };
- shop s[MAXN];
- plant p[MAXN];
- LL g[MAXN << ][MAXN << ];
- LL level[MAXN<<];
- LL T, n, m, l, st, ed, ans, tmp;
- bool bfs()
- {
- memset(level, -, sizeof(level));
- level[st] = ;
- queue<LL> q;
- q.push(st);
- while (!q.empty())
- {
- LL f = q.front();
- q.pop();
- for (LL i = ; i <= ed; i++)
- {
- if (level[i] == - && g[f][i] > )
- {
- level[i] = level[f] + ;
- q.push(i);
- }
- }
- }
- return level[ed] > ;
- }
- LL dinic(LL k, LL low)
- {
- if (k == ed)return low;
- LL a;
- for (LL i = ; i <= ed; i++)
- {
- if (level[i] == level[k] + && g[k][i] > && (a = dinic(i, min(low, g[k][i]))))
- {
- g[k][i] -= a;
- g[i][k] += a;
- return a;
- }
- }
- return ;
- }
- void solve()
- {
- ans = ;
- while (bfs())
- {
- while (tmp = dinic(st, INF))
- ans += tmp;
- }
- }
- int main()
- {
- sf(T);
- for (LL cas = ; cas <= T; cas++)
- {
- sf(n), sf(m), sf(l);
- for (LL i = ; i <= n; i++)
- {
- sf(p[i].pay), sf(p[i].time);
- p[i].id = i;
- }
- for (LL i = ; i <= m; i++)
- {
- sf(s[i].pro);
- sf(s[i].cnt);
- s[i].time = ;
- for (LL j = ; j < s[i].cnt; j++)
- {
- sf(s[i].pl[j]);
- s[i].time = max(s[i].time, p[s[i].pl[j]].time);
- }
- }
- sort(p + , p + + n);
- bool f = false;
- st = n + m + , ed = st + ;
- printf("Case #%lld: ", cas);
- for (LL i = ; i <= n; i++)
- {
- memset(g, , sizeof(g));
- for (LL j = ; j <= i; j++)
- g[p[j].id][ed] = p[j].pay;
- LL tot = ;
- for (LL j = ; j <= m; j++)
- {
- if (s[j].time <= p[i].time)
- {
- tot += s[j].pro;
- g[st][j + n] = s[j].pro;
- for (LL k = ; k < s[j].cnt; k++)
- g[j + n][s[j].pl[k]] = INF;
- }
- }
- solve();
- ans = tot - ans;
- if (ans >= l)
- {
- printf("%lld %lld\n", p[i].time, ans);
- f = true;
- break;
- }
- }
- if (!f)
- printf("impossible\n");
- }
- }
Less Time, More profit 最大权闭合子图(最大流最小割)的更多相关文章
- HDU 5855 Less Time, More profit 最大权闭合子图
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5855 Less Time, More profit Time Limit: 2000/1000 MS ...
- 【最大权闭合子图 最小割】bzoj1497: [NOI2006]最大获利
最大权闭合子图的模型:今天才发现dinic板子是一直挂的…… Description 新的技术正冲击着手机通讯市场,对于各大运营商来说,这既是机遇,更是挑战.THU集团旗下的CS&T通讯公司在 ...
- 洛谷 P4174 [NOI2006]最大获利 && 洛谷 P2762 太空飞行计划问题 (最大权闭合子图 && 最小割输出任意一组方案)
https://www.luogu.org/problemnew/show/P4174 最大权闭合子图的模板 每个通讯站建一个点,点权为-Pi:每个用户建一个点,点权为Ci,分别向Ai和Bi对应的点连 ...
- bzoj 1497 [NOI2006]最大获利【最大权闭合子图+最小割】
不要被5s时限和50000点数吓倒!大胆网络流!我一个5w级别的dinic只跑了1s+! 看起来没有最大权闭合子图的特征--限制,实际上还是有的. 我们需要把中转站看成负权点,把p看成点权,把客户看成 ...
- 洛谷 P2762 太空飞行计划问题 【最大权闭合子图+最小割】
--一道难在读入的题. 最后解决方案直接getline一行然后是把读优拆掉放进函数,虽然很丑但是过了. 然后就是裸的最大权闭合子图了,把仪器当成负权点向t连流量为其价格的边,s向实验连流量为实验报酬的 ...
- BZOJ 1565 / P2805 [NOI2009]植物大战僵尸 (最大权闭合子图 最小割)
题意 自己看吧 BZOJ传送门 分析 - 这道题其实就是一些点,存在一些二元限制条件,即如果要选uuu则必须选vvv.求得到的权值最大是多少. 建一个图,如果选uuu必须选vvv,则uuu向vvv连边 ...
- 【最大权闭合子图/最小割】BZOJ3438-小M的作物【待填】
[题目大意] 小M在MC里开辟了两块巨大的耕地A和B(你可以认为容量是无穷),现在,小P有n中作物的种子,每种作物的种子有1个(就是可以种一棵作物)(用1...n编号),现在,第i种作物种植在A中种植 ...
- HDU5855 Less Time, More profit(最大权闭合子图)
题目 Source http://acm.hdu.edu.cn/showproblem.php?pid=5855 Description The city planners plan to build ...
- 2018.11.06 NOIP训练 最大获利(profit)(01分数规划+最大权闭合子图)
传送门 好题啊. ∑i<jpi,jK∗(200−K)>X\frac{\sum_{i<j}p_{i,j}}{K*(200-K)}>XK∗(200−K)∑i<jpi,j ...
随机推荐
- Android开发学习——Android Studio配置SVN
一.基本配置 1. 下载这个,然后双击 安装,按下图这样选 然后 傻瓜式安装 2. 进入Android studio设置:Use Command Line Client 选择浏览到第1步你本地安装 T ...
- 如何成为一名优秀的 iOS 开发工程师
如果你是一位专业的iOS开发工程师,你应该为自己感到自豪.因为你能在强大的iOS系统下,一展身手实现自己和他人的想法,这是一件令人无比激动的事情. 作为一名iOS开发工程师,你一定想成为行业的佼佼者. ...
- react学习文档
转自http://www.ruanyifeng.com/blog/2015/03/react.html,阮一峰老师的博客. 最近想学习react,官方文档的例子不是那么浅显易懂,看了相关博客,觉得阮一 ...
- 怪物猎人OL简单测评与碎碎念
请移步我的个人网站查看: www.wuduojia.cn
- 图解 TCP/IP 第六章 TCP与UDP 笔记6.1 传输层的作用
图解 TCP/IP 第六章 TCP与UDP 笔记6.1 传输层的作用 传输层必须指出这个具体的程序,为了实现这一功能,使用端口号这样一种识别码.根据端口号,就可以识别在传输层上一层的应用程 ...
- html中 accept 属性
1.HTML <input> 标签的 accept 属性 在文件上传中使用 accept 属性,本例中的输入字段可以接受 GIF 和 JPEG 两种图像: <form> < ...
- pil - pillow 的版本
pip install PIL python2版本 pip install pillow python3版本
- NLog小记
NLog安装: Install-Package NLog NLog配置: <?xml version="1.0" encoding="utf-8" ?&g ...
- mysql 修改表的字段
修改一个表的字段 ALTER TABLE `member` CHANGE `memberid` `memberid` bigint unsigned; 修改含有外键的字段 -- 执行 begin 到 ...
- WebDAV协议
WebDAV是一项基于 Http1.1 协议的通信协议.它扩展了HTTP 1.1,在Get.Post.Put.Delete 等HTTP标准方法外添加了新方法,使应用程序可对Web Server直接读写 ...