The city planners plan to build N plants in the city which has M shops.

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 最大权闭合子图(最大流最小割)的更多相关文章

  1. HDU 5855 Less Time, More profit 最大权闭合子图

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5855 Less Time, More profit Time Limit: 2000/1000 MS ...

  2. 【最大权闭合子图 最小割】bzoj1497: [NOI2006]最大获利

    最大权闭合子图的模型:今天才发现dinic板子是一直挂的…… Description 新的技术正冲击着手机通讯市场,对于各大运营商来说,这既是机遇,更是挑战.THU集团旗下的CS&T通讯公司在 ...

  3. 洛谷 P4174 [NOI2006]最大获利 && 洛谷 P2762 太空飞行计划问题 (最大权闭合子图 && 最小割输出任意一组方案)

    https://www.luogu.org/problemnew/show/P4174 最大权闭合子图的模板 每个通讯站建一个点,点权为-Pi:每个用户建一个点,点权为Ci,分别向Ai和Bi对应的点连 ...

  4. bzoj 1497 [NOI2006]最大获利【最大权闭合子图+最小割】

    不要被5s时限和50000点数吓倒!大胆网络流!我一个5w级别的dinic只跑了1s+! 看起来没有最大权闭合子图的特征--限制,实际上还是有的. 我们需要把中转站看成负权点,把p看成点权,把客户看成 ...

  5. 洛谷 P2762 太空飞行计划问题 【最大权闭合子图+最小割】

    --一道难在读入的题. 最后解决方案直接getline一行然后是把读优拆掉放进函数,虽然很丑但是过了. 然后就是裸的最大权闭合子图了,把仪器当成负权点向t连流量为其价格的边,s向实验连流量为实验报酬的 ...

  6. BZOJ 1565 / P2805 [NOI2009]植物大战僵尸 (最大权闭合子图 最小割)

    题意 自己看吧 BZOJ传送门 分析 - 这道题其实就是一些点,存在一些二元限制条件,即如果要选uuu则必须选vvv.求得到的权值最大是多少. 建一个图,如果选uuu必须选vvv,则uuu向vvv连边 ...

  7. 【最大权闭合子图/最小割】BZOJ3438-小M的作物【待填】

    [题目大意] 小M在MC里开辟了两块巨大的耕地A和B(你可以认为容量是无穷),现在,小P有n中作物的种子,每种作物的种子有1个(就是可以种一棵作物)(用1...n编号),现在,第i种作物种植在A中种植 ...

  8. HDU5855 Less Time, More profit(最大权闭合子图)

    题目 Source http://acm.hdu.edu.cn/showproblem.php?pid=5855 Description The city planners plan to build ...

  9. 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<j​pi,j​​ ...

随机推荐

  1. Oracle用户角色权限相关视图

    常用相关视图概述 DBA_SYS_PRIVS: 查询某个用户所拥有的系统权限 USER_SYS_PRIVS: 当前用户所拥有的系统权限 SESSION_PRIVS: 当前用户所拥有的全部权限 ROLE ...

  2. java自动包装与解包

    关于java的自动包装机制想必大家都用过吧,一般这些机制都用于在往容器中存储基本类型数据的时候,因为容器中不允许存在基本数据类型,所以就会调用自动包装机制,将基本数据类型转换为对象,将基本数据保存在对 ...

  3. SQL将查询出来的多列的值拼接成一个字符串

    -- 单列拼接,先查出一行,再加上逗号,接着拼接 查出的下一行 SELECT GROUP_CONCAT(user_id) FROM user; -- result 160,160,160,196 -- ...

  4. JavaScript——blob、file、flieReader、createObjectURL

    https://blog.csdn.net/opengl_es/article/details/44336477 https://www.cnblogs.com/hhhyaaon/p/5928152. ...

  5. 本地连接批处理修改IP

    例子: 本地连接修改IP netsh interface ip delete dns "本地连接" addr=allnetsh interface ip add dns " ...

  6. thinkphp5 404 file_put_contents 无法打开流:权限被拒绝

    如果你用TP的时间比较长,或者说你比较了解TP的人都会知道,TP的runtime它需要的权限是很大的,如果你只给一般权限肯定是不行的,通常都是给runtime权限:777: linux命令如下: cd ...

  7. 迅为iTOP-4418嵌入式开发板初体验

    iTOP-4418开发板预装 Android4.4.4 系统, 支持9.7 寸.7 寸.4.3 寸屏幕. 参数:核心板参数 尺寸 50mm*60mm高度 核心板连接器为1.5mmCPU ARM Cor ...

  8. Android(java)学习笔记187:多媒体之SurfaceView

    1. SurfaceView:     完成单位时间内界面的快速切换(游戏界面流畅感). 我们之前知道一般的View,只能在主线程里面显示,主线程中更新UI.但是SurfaceView可以在子线程中里 ...

  9. mysql.connector.errors.IntegrityError: 1048 (23000): Column 'request_url' cannot be null

    箭头指向的2的方向 少了一个request_url的值 调试: 直接 执行sql语句 是没问题的, 这样就知道问题是出在代码的逻辑 处理了: INSERT INTO response_time (nu ...

  10. flask中模板日期格式控制和jinja2中模板格式控制

    1.flask的模块语言采用的是jinja2,首先说一下jinja2中的模板格式控制的使用,即模板自定义filters的使用. python的脚本如下(采用的是格式显示日期): 1 from jinj ...