题解:

求比值用分数规划,单个求太慢了套整体二分

然后求二分图最小割

// luogu-judger-enable-o2
#include<iostream>
#include<cstdio>
#include<cstring>
#include<vector>
#include<queue>
#include<cmath>
using namespace std;
const double eps=1e-10;
const int maxn=1000;
const int oo=1000000000; int n,m;
int n1,m1;
double val[maxn]; int dcmp(double x){
if(fabs(x)<eps)return 0;
if(x<0)return -1;
else return 1;
} struct ShortestPath{
int rx[100009],ry[100009],s[100009],t[100009];
int cntedge;
int head[maxn];
int to[100009],nex[100009];
double dist[100009];
void Addedge(int x,int y,double z){
nex[++cntedge]=head[x];
to[cntedge]=y;
dist[cntedge]=z;
head[x]=cntedge;
} void readin(){
for(int i=1;i<=m;++i)scanf("%d%d%d%d",&rx[i],&ry[i],&t[i],&s[i]);
} queue<int>q;
int inq[maxn];
double d[maxn];
void Spfa(){
for(int i=1;i<=n;++i){
d[i]=oo;inq[i]=0;
}
inq[n]=1;d[n]=0;q.push(n);
while(!q.empty()){
int x=q.front();q.pop();inq[x]=0;
for(int i=head[x];i;i=nex[i]){
if(d[x]+dist[i]<d[to[i]]){
d[to[i]]=d[x]+dist[i];
if(!inq[to[i]]){
q.push(to[i]);
inq[to[i]]=1;
}
}
}
}
} int a[maxn],b[maxn],c[maxn];
void Div(int l,int r,double Lo,double Hi){
if(l>r)return;
if(dcmp(Lo-Hi)==0){
for(int i=l;i<=r;++i)val[a[i]]=Lo;
return;
}
double midans=(Lo+Hi)/2.0;
memset(head,0,sizeof(head));
cntedge=0;
for(int i=1;i<=m;++i)Addedge(rx[i],ry[i],t[i]-midans*s[i]);
Spfa();
int t1=0,t2=0;
for(int i=l;i<=r;++i){
if(d[a[i]]<=0){
b[++t1]=a[i];
}else{
c[++t2]=a[i];
}
}
for(int i=1;i<=t1;++i)a[l+i-1]=b[i];
for(int i=1;i<=t2;++i)a[l+t1+i-1]=c[i];
Div(l,l+t1-1,Lo,midans);
Div(l+t1,r,midans,Hi);
}
void Getst(){
for(int i=1;i<=n1;++i)a[i]=i;
for(int i=1;i<=n1;++i)val[i]=oo;
Div(1,n1,0,1000.0);
}
}P; struct NetworkFlow{
struct Edge{
int from,to;
double cap,flow;
};
vector<int>G[maxn];
vector<Edge>edges;
void Addedge(int x,int y,double z){
Edge e;
e.from=x;e.to=y;e.cap=z;e.flow=0;
edges.push_back(e);
e.from=y;e.to=x;e.cap=0;e.flow=0;
edges.push_back(e);
int c=edges.size();
G[x].push_back(c-2);
G[y].push_back(c-1);
} int s,t;
int d[maxn];
int vis[maxn];
queue<int>q;
int Bfs(){
memset(vis,0,sizeof(vis));
vis[s]=1;d[s]=0;q.push(s);
while(!q.empty()){
int x=q.front();q.pop();
for(int i=0;i<G[x].size();++i){
Edge e=edges[G[x][i]];
if((dcmp(e.cap-e.flow)>0)&&(!vis[e.to])){
vis[e.to]=1;
d[e.to]=d[x]+1;
q.push(e.to);
}
}
}
return vis[t];
} double Dfs(int x,double a){
if((x==t)||(dcmp(a)==0))return a; double nowflow=0,f=0;
for(int i=0;i<G[x].size();++i){
Edge e=edges[G[x][i]];
if(d[x]+1==d[e.to]){
f=Dfs(e.to,min(a,e.cap-e.flow));
if(dcmp(f)>0){
nowflow+=f;
a-=f;
edges[G[x][i]].flow+=f;
edges[G[x][i]^1].flow-=f;
if(dcmp(a)==0)break;
}
}
}
return nowflow;
} double Maxflow(){
double flow=0;
while(Bfs())flow+=Dfs(s,oo*1.0);
return flow;
} void Sol(){
s=n1+1;t=s+1;
for(int i=1;i<=n1;++i){
if(i%2)Addedge(s,i,val[i]);
else Addedge(i,t,val[i]);
}
while(m1--){
int x,y;
scanf("%d%d",&x,&y);
if((dcmp(val[x]-1000)==0)&&(dcmp(val[y]-1000)==0)){
printf("-1\n");return;
}
Addedge(x,y,oo*1.0);
}
printf("%.1f\n",Maxflow());
}
}F; int main(){
scanf("%d%d",&n,&m);
P.readin();
scanf("%d%d",&m1,&n1);
P.Getst();
F.Sol();
return 0;
}

  

BZOJ 2285 [Sdoi2011]保密的更多相关文章

  1. bzoj 2285 [Sdoi2011]保密(二分,spfa + 最大流)

    Description 现在,保密成为一个很重要也很困难的问题.如果没有做好,后果是严重的.比如,有个人没有自己去修电脑,又没有拆硬盘,后来的事大家都知道了. 当然,对保密最需求的当然是军方,其次才是 ...

  2. 【BZOJ2285】[SDOI2011]保密(分数规划,网络流)

    [BZOJ2285][SDOI2011]保密(分数规划,网络流) 题面 BZOJ 洛谷 题解 首先先读懂题目到底在干什么. 发现要求的是一个比值的最小值,二分这个最小值\(k\),把边权转换成\(t- ...

  3. [BZOJ 2285] [SDOI 2011] 保密

    Description 传送门 Solution 这道题的最大难点在于读懂题意(雾 分数规划求出 \(n\) 到 \(1\cdots n_1\) 每个点的最小 \(\sum\frac{t_i}{s_i ...

  4. BZOJ 2243: [SDOI2011]染色 [树链剖分]

    2243: [SDOI2011]染色 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 6651  Solved: 2432[Submit][Status ...

  5. BZOJ 2286: [Sdoi2011]消耗战

    2286: [Sdoi2011消耗战 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 2082  Solved: 736[Submit][Status] ...

  6. bzoj 2242: [SDOI2011]计算器 BSGS+快速幂+扩展欧几里德

    2242: [SDOI2011]计算器 Time Limit: 10 Sec  Memory Limit: 512 MB[Submit][Status][Discuss] Description 你被 ...

  7. BZOJ 2241: [SDOI2011]打地鼠 暴力

    2241: [SDOI2011]打地鼠 Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline/pro ...

  8. bzoj 2244: [SDOI2011]拦截导弹 cdq分治

    2244: [SDOI2011]拦截导弹 Time Limit: 30 Sec  Memory Limit: 512 MBSec  Special JudgeSubmit: 237  Solved: ...

  9. bzoj 2243 [SDOI2011]染色(树链剖分,线段树)

    2243: [SDOI2011]染色 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 4637  Solved: 1726[Submit][Status ...

随机推荐

  1. tan?

    痰是一种急.慢性气管--支气管炎,咳.痰.喘.炎是下呼吸道感染的常见主征.下呼吸道感染有急性和慢性之分.急性感染主要的是急性气管--支气管炎,是呼吸系统最常见的一种疾病,多由感染.物理化学刺激或过敏引 ...

  2. C#最小化到托盘+双击托盘恢复+禁止运行多个该程序

    托盘程序的制作: 1.添加notifyIcon控件,并添加Icon,否则托盘没有图标(托盘右键菜单也可直接在属性里添加):2.响应Form的Resize或SizeChanged消息: // Hide ...

  3. Python中基于Unpacking与Packing进行分割,组合操作的嵌套元组数据结构的应用

    对于二叉树,图等,Python可采用基于Packing与Unpacking形成的嵌套元组数据结构来模拟,这里Packing指,比如a=b,c则,a就成了一个包含b,c的元组,Unpacking是指,比 ...

  4. JAVA 使用模板创建DOCX文档)(XDocService 使用报错条数过多报错链接不上服务器)

    详细解释https://xdoc.iteye.com/blog/2399451 https://xdoc.iteye.com/  导入 XDocService.jar   我说一下我遇到的问题 我从数 ...

  5. NO7 利用三剑客awk-grep-sed-head-tail等7种方法实践

    ·seq   sequence  #序列·sed   stream editor  #(三剑客老二)流编辑器.实现对文件的增删改替换查.        -n #取消默认输出.sed -n '20,30 ...

  6. POJ1611 && POJ2524 并查集入门

    The Suspects Time Limit: 1000MS   Memory Limit: 20000K Total Submissions: 28293   Accepted: 13787 De ...

  7. node - 获取 token

     String(req.headers.authorization || '').split(' ').pop() 

  8. 【转载】redis.windows.conf 参数说明

    1. Redis默认不是以守护进程的方式运行,可以通过该配置项修改,使用yes启用守护进程 daemonize no 2. 当Redis以守护进程方式运行时,Redis默认会把pid写入/var/ru ...

  9. 一百一十一、SAP的OO-ALV之五,显示ALV表格

    一.在屏幕里面有2部分,(PROCESS BEFORE OUTPUT 用于显示, PROCESS AFTER INPUT用于数据处理).我们创建的display_alv函数, 二.display_al ...

  10. 032-PHP中关于数组排序的usort()函数

    <?php function re($a, $b) { return ($a < $b) ? 1 : -1; } $x = array(1, 3, 2, 5, 9); usort($x, ...