BZOJ 4819 新生舞会
第一句话:算出3.363636的孩子啊,你跑错流种了。
貌似上一篇我讲SDOI出原题?嘿还真是!
半个月前有一个叫WG的男人给我们搞过一场考试... ...
里面有一道题叫做保密... ...SDOI2011... ...
对于每个点求ΣS/ΣT最值然后转跑浮点数网络流... ...
是不是感觉我在讲这道题的正解... ...没错正解就是这样... ...所以我说是原题吧。
跟 保密 是一样的思路。求Σa/Σb的最值,可以用二分答案来做。
Σa/Σb的最大值怎么求呢?设一个当前答案ans;
显然如果有方案使Σa/Σb>ans则答案更优。
把式子化一下得:
Σa>Σb*ans;
即
Σa-Σb*ans>0;
即
Σ(a-b*ans)>0;
每次重新建图或者带着二分的mid跑最大费用最大流即可。
没错跑出3.363636是跑的最小费用最大流... ...别问我怎么知道的。
用KM算法算最大权匹配跑的更快奈何我不会。好在它是一个左右相等的完全二分图,用费用流做也是可以的。
出题人良心发现没有卡费用流真是资磁。
还有就是浮点数二分答案跟整数不一样,要用eps。
有哪位大佬能够告诉我 为什么我的费用流 跑的那么慢吗?
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <algorithm>
#include <queue>
#include <cstring>
#define LL long long
#define dob double
using namespace std; const int N = 110;
const int M = 100010;
const dob eps = 1e-7;
const dob dobInf = 19260817.2333;
struct Node{int to,C;double val;int next;}E[M];
int head[M],tot,n,S,T,up[M],In[M];
dob a[N][N],b[N][N],far[M],Ans; int gi()
{
int x=0,res=1;char ch=getchar();
while(ch<'0' || ch>'9'){if(ch=='-')res=-res;ch=getchar();}
while(ch>='0'&&ch<='9')x=x*10+ch-48,ch=getchar();
return x*res;
} inline void link(int u,int v,int c,double val)
{
E[++tot]=(Node){v,c,val,head[u]};
head[u]=tot;
E[++tot]=(Node){u,0,-val,head[v]};
head[v]=tot;
} inline void slink(double Eps)
{
memset(head,0,sizeof(head));tot=1;
for(int i=1;i<=n;++i)
{
link(S,i,1,0.0000000);
link(i+n,T,1,0.0000000);
for(int j=1;j<=n;++j)
link(i,n+j,1,(a[i][j])-Eps*b[i][j]);
}
} inline bool spfa()
{
for(int i=0;i<=T;++i)
far[i]=-dobInf;
memset(up,0,sizeof(up));
queue<int>Q;Q.push(S);
far[S]=0.000000;In[S]=1;
while(!Q.empty())
{
int x=Q.front();Q.pop();
for(int e=head[x];e;e=E[e].next)
if(E[e].C && far[x]+E[e].val>far[E[e].to])
{
up[E[e].to]=e;
far[E[e].to]=far[x]+E[e].val;
if(!In[E[e].to])
Q.push(E[e].to),In[E[e].to]=1;
}
In[x]=0;
}
if(!up[T])return false;
for(int i=T;i^S;i=E[up[i]^1].to)
E[up[i]].C--,E[up[i]^1].C++;
Ans-=far[T];return true;
} inline bool check()
{
Ans=0.00;
while(spfa())
if(Ans>=0.00)return true;
return Ans>=0.00;
} int main()
{
n=gi();S=2*n+1,T=2*n+2;
for(int i=1;i<=n;++i)
for(int j=1;j<=n;++j)
scanf("%lf",&a[i][j]);
for(int i=1;i<=n;++i)
for(int j=1;j<=n;++j)
scanf("%lf",&b[i][j]);
dob l=0.0,r=10000,ans=r;
while(r-l>eps)
{
double mid=(l+r)/2.0;
slink(mid);
if(check())r=mid,ans=mid;
else l=mid;
}
printf("%.6lf\n",ans);
return 0;
}
BZOJ 4819 新生舞会的更多相关文章
- 【BZOJ 4819】 4819: [Sdoi2017]新生舞会 (0-1分数规划、二分+KM)
4819: [Sdoi2017]新生舞会 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 601 Solved: 313 Description 学校 ...
- bzoj 4819: [Sdoi2017]新生舞会
Description 学校组织了一次新生舞会,Cathy作为经验丰富的老学姐,负责为同学们安排舞伴.有n个男生和n个女生参加舞会 买一个男生和一个女生一起跳舞,互为舞伴.Cathy收集了这些同学之间 ...
- [BZOJ 4819] [SDOI 2017] 新生舞会
Description 学校组织了一次新生舞会,Cathy作为经验丰富的老学姐,负责为同学们安排舞伴. 有 \(n\) 个男生和 \(n\) 个女生参加舞会买一个男生和一个女生一起跳舞,互为舞伴. C ...
- 4819: [Sdoi2017]新生舞会(分数规划)
4819: [Sdoi2017]新生舞会 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1031 Solved: 530[Submit][Statu ...
- BZOJ4819 新生舞会
4819: [Sdoi2017]新生舞会 Time Limit: 10 Sec Memory Limit: 128 MB Description 学校组织了一次新生舞会,Cathy作为经验丰富的老学 ...
- 【BZOJ4819】新生舞会(分数规划,网络流)
[BZOJ4819]新生舞会(分数规划,网络流) 题面 BZOJ Description 学校组织了一次新生舞会,Cathy作为经验丰富的老学姐,负责为同学们安排舞伴.有n个男生和n个女生参加舞会 买 ...
- [BZOJ4819][SDOI2017]新生舞会(分数规划+费用流,KM)
4819: [Sdoi2017]新生舞会 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1097 Solved: 566[Submit][Statu ...
- bzoj4819 [Sdoi2017]新生舞会
Description 学校组织了一次新生舞会,Cathy作为经验丰富的老学姐,负责为同学们安排舞伴.有n个男生和n个女生参加舞会买一个男生和一个女生一起跳舞,互为舞伴.Cathy收集了这些同学之间的 ...
- [Sdoi2017]新生舞会 [01分数规划 二分图最大权匹配]
[Sdoi2017]新生舞会 题意:沙茶01分数规划 貌似\(*10^7\)变成整数更科学 #include <iostream> #include <cstdio> #inc ...
随机推荐
- 机器学习 F1-Score 精确率 - P 准确率 -Acc 召回率 - R
准确率 召回率 精确率 : 准确率->accuracy, 精确率->precision. 召回率-> recall. 三者很像,但是并不同,简单来说三者的目的对象并不相同. 大多时候 ...
- Android自定义指示器时间轴
指示器时间轴在外卖.购物类的APP里会经常用到,效果大概就像下面这样,看了网上很多文章,大都是自己绘制,太麻烦,其实通过ListView就可以实现. 在Activity关联的布局文件activit ...
- 基于 HTML5 Canvas 的 3D 模型列表贴图
少量图片对于我们赋值是没有什么难度,但是如果图片的量大的话,我们肯定希望能很直接地显示在界面上供我们使用,再就是排放的位置等等,这些都需要比较直观的操作,在实际应用中会让我们省很多力以及时间.下面这个 ...
- 企业实战Nginx+Tomcat动静分离架构的技术分享
Nginx动静分离简单来说就是把动态跟静态请求分开,不能理解成只是单纯的把动态页面和静态页面物理分离.严格意义上说应该是动态请求跟静态请求分开,可以理解成使用Nginx处理静态页面,Tomcat.Re ...
- 洛谷教主花园dp
洛谷-教主的花园-动态规划 题目描述 教主有着一个环形的花园,他想在花园周围均匀地种上n棵树,但是教主花园的土壤很特别,每个位置适合种的树都不一样,一些树可能会因为不适合这个位置的土壤而损失观赏价 ...
- VMware中克隆虚拟机出现eth0改变为eth1情况
解决如下: 查看复制虚拟机网卡信息如下: root@jcfx-2 ~]# ifconfig eth1 Link encap:Ethernet HWaddr 00:0C:29:CC:32:63 inet ...
- PHP 八种基本的数据类型小结
四种标量类型: boolean (布尔型) integer (整型) float (浮点型, 也称作 double) string (字符串) 两种复合类型: array (数组) object (对 ...
- 最近整理AI相关感想
前言 目前笔者致力于 在AI 开发研究,四大平台里,百度AI 提供 的开发者资料是最全,开发的友好度也是最高的,很多都已经集成在SDK中,支持许多语言体系. 其实 作为公司层面的考虑,针对技术的研究出 ...
- 通过Nutch扩展点开发插件(添加自定义索引字段到solr)
爬虫系统:通过Nutch扩展点开发插件(添加自定义索引字段到solr) 准备工作 爬虫环境 -- nutch2.3.1 + solr4.10.3 + hbase0.98 开发环境 -- Eclipse ...
- System.ServiceModel.CommunicationException: 已超过传入消息(65536)的最大消息大小配额。若要增加配额,请使用相应绑定元素上的 MaxReceivedMessageSize 属性。