hdu_5585_Less Time, More profit(二分+最大权闭合图)
题目链接:hdu_5855_Less Time, More profit
题意:
有n个工厂,每建一个工厂要花费vi,需要时间ti,然后有m个商店,每个商店需要在指定的k个工厂中进货,才能盈利,如果其中一个不在,都不能盈利,问在满足利润大于等于k的情况下的最少时间t,和在t时刻的最大利润
题解:
二分时间+网络流的最大权闭合图。比赛的时候搞了半天的题意才看懂,4点过才开始写网络流,然而没时间调试了。然后就GG了
#include<bits/stdc++.h>
#define mst(a,b) memset(a,b,sizeof(a));
#define F(i,a,b) for(int i=a;i<=b;++i)
using namespace std; const int N=,inf=~0U>>,M=;
struct edge{int t,f;edge*nxt,*pair;}*g[N],*d[N],pool[M],*cur=pool;
struct ISAP{
int n,m,i,S,T,h[N],gap[N],maxflow;
void init(int ss,int tt){for(S=ss,T=tt,cur=pool,i=;i<=T;i++)g[i]=d[i]=NULL,h[i]=gap[i]=;}
void add(int s,int t,int f){
edge*p=cur++;p->t=t,p->f=f,p->nxt=g[s],g[s]=p;
p=cur++,p->t=s,p->f=,p->nxt=g[t],g[t]=p;
g[s]->pair=g[t],g[t]->pair=g[s];
}
int sap(int v,int flow){
if(v==T)return flow;
int rec=;
for(edge*p=d[v];p;p=p->nxt)if(h[v]==h[p->t]+&&p->f){
int ret=sap(p->t,min(flow-rec,p->f));
p->f-=ret;p->pair->f+=ret;d[v]=p;
if((rec+=ret)==flow)return flow;
}
if(!(--gap[h[v]]))h[S]=T;
gap[++h[v]]++;d[v]=g[v];
return rec;
}
int get_ans(){
for(gap[maxflow=]=T,i=;i<=T;i++)d[i]=g[i];
while(h[S]<T)maxflow+=sap(S,inf);
return maxflow;
}
}G; int t,n,m,l,L,R,ansf,ic=,all;
struct pat{
int v,t;
}pt[];
struct shop{
int v,k,vis[];
}sp[]; bool check(int x)
{
all=;
G.init(,);
F(i,,n)if(pt[i].t<=x)G.add(i+,,pt[i].v);
int vv[];
mst(vv,);
F(i,,m)
{
int fg=;
F(j,,sp[i].k)
if(pt[sp[i].vis[j]].t>x)fg=;
if(fg)vv[i]=;
}
F(i,,m)if(vv[i])G.add(,i+,sp[i].v);
F(i,,m)if(vv[i])
{
all+=sp[i].v;
F(j,,sp[i].k)G.add(i+,sp[i].vis[j]+,inf);
}
ansf=all-G.get_ans();
if(ansf>=l)return ;
else return ;
} int main(){
scanf("%d",&t);
while(t--)
{
ansf=,all=;
L=1e9,R=;
scanf("%d%d%d",&n,&m,&l);
F(i,,n)scanf("%d%d",&pt[i].v,&pt[i].t),L=min(L,pt[i].t),R=max(R,pt[i].t);
F(i,,m)
{
scanf("%d%d",&sp[i].v,&sp[i].k);
F(j,,sp[i].k)scanf("%d",&sp[i].vis[j]);
}
int mid,ans=;
while(L<=R)
{
mid=(L+R)>>;
if(check(mid))R=(ans=mid)-;
else L=mid+;
}
check(ans);
if(ansf>=l)printf("Case #%d: %d %d\n",ic++,ans,ansf);
else printf("Case #%d: impossible\n",ic++);
}
}
hdu_5585_Less Time, More profit(二分+最大权闭合图)的更多相关文章
- POJ 3155 Hard Life 最大密度子图 最大权闭合图 网络流 二分
		
http://poj.org/problem?id=3155 最大密度子图和最大权闭合图性质很相近(大概可以这么说吧),一个是取最多的边一个是取最多有正贡献的点,而且都是有选一种必须选另一种的限制,一 ...
 - poj 2987 最大权闭合图
		
Language: Default Firing Time Limit: 5000MS Memory Limit: 131072K Total Submissions: 8744 Accept ...
 - hdu 3879 Base Station  最大权闭合图
		
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3879 A famous mobile communication company is plannin ...
 - poj 2987 Firing  最大权闭合图
		
题目链接:http://poj.org/problem?id=2987 You’ve finally got mad at “the world’s most stupid” employees of ...
 - POJ_2987_Firing_(最大流+最大权闭合图)
		
描述 http://poj.org/problem?id=2987 要炒员工鱿鱼,炒了一个人,他的下属一定被炒.给出每个人被炒后公司的收益(负值表示亏损),问怎样炒公司收益最大,以及这种方法炒了几个人 ...
 - POJ2987 Firing 【最大权闭合图】
		
POJ2987 Firing Description You've finally got mad at "the world's most stupid" employees o ...
 - POJ 2987 Firing(最大流最小割の最大权闭合图)
		
Description You’ve finally got mad at “the world’s most stupid” employees of yours and decided to do ...
 - hdu - 4971 - A simple brute force problem.(最大权闭合图)
		
题意:n(n <= 20)个项目,m(m <= 50)个技术问题,做完一个项目能够有收益profit (<= 1000),做完一个项目必须解决对应的技术问题,解决一个技术问题须要付出 ...
 - 【TYVJ】1338 QQ农场(最大流+最大权闭合图)
		
http://tyvj.cn/Problem_Show.aspx?id=1338 时间才排到rank7,还不快啊囧.isap我常数都写得那么小了... 最大权闭合图看我另一篇博文吧 此题很明显的模型. ...
 
随机推荐
- sequekize
			
关于sequelize的准备工作这里不再赘述. 一.引入sequelize模块 var Sequelize = require('sequelize'); 二.连接数据库 var sequelize ...
 - js中角度计算
			
-. js 关于三角函数算法 弧度 和 角度的理解, 以及相互转换 角的两种单位 度 和 弧 1.弧度的定义 我们知道"度"的定义是,"两条射 ...
 - JSON跟JSONP的区别以及实战
			
前言 由于Sencha Touch 2这种开发模式的特性,基本决定了它原生的数据交互行为几乎只能通过AJAX来实现. 当然了,通过调用强大的PhoneGap插件然后打包,你可以实现100%的Socke ...
 - hdu1722
			
链接 一份切成q份需要q刀,切成p份需要p刀:切的部分总会有重复,即gcd(p,q),减去重复部分就是要切的刀数 #include<stdio.h> int gcd(int n,int m ...
 - WPF中自定义绘制内容
			
先说结论:实现了在自定义大小的窗口中,加载图片,并在图片上绘制一个矩形框:且在窗口大小改变的情况,保持绘制的矩形框与图片的先对位置不变. 在WinForm中,我们可以很方便地绘制自己需要的内容,在WP ...
 - top batch output
			
echo 3 > sudo tee /proc/sys/vm/drop_caches top -d30 -bn20 > a
 - Openjudge-NOI题库-对齐输出
			
题目描述 Description 读入三个整数,按每个整数占8个字符的宽度,右对齐输出它们. 输入输出格式 Input/output 输入格式: 只有一行,包含三个整数,整数之间以一个空格分开. ...
 - Scala内部类
			
注意:Java内部类从属于外部类,而Scala内部类从属于对象(外部类的实例本身).
 - 使用sublime text3 连接sftp/ftp(远程服务器)
			
首先说明的是Sumblime Text 3,下载安装后,打开软件 在红色箭头指定的控制区域粘贴下面这段英文 import urllib.request,os,hashlib; h = '2915d18 ...
 - php中函数 vsprintf() 和 var_export()
			
把格式化字符串写入变量中: <?php $number = 9; $str = "Beijing"; $txt = vsprintf("There are %u m ...