P3705 [SDOI2017]新生舞会

题目描述

学校组织了一次新生舞会,\(Cathy\)作为经验丰富的老学姐,负责为同学们安排舞伴。

有\(n\)个男生和\(n\)个女生参加舞会买一个男生和一个女生一起跳舞,互为舞伴。

\(Cathy\)收集了这些同学之间的关系,比如两个人之前认识没计算得出\(a_{i,j}\)

\(Cathy\)还需要考虑两个人一起跳舞是否方便,比如身高体重差别会不会太大,计算得出\(b_{i,j}\) ,表示第\(i\)个男生和第\(j\)个女生一起跳舞时的不协调程度。

当然,还需要考虑很多其他问题。

\(Cathy\)想先用一个程序通过\(a_{i,j}\)和\(b_{i,j}\) ,求出一种方案,再手动对方案进行微调。

\(Cathy\)找到你,希望你帮她写那个程序。

一个方案中有\(n\)对舞伴,假设没对舞伴的喜悦程度分别是\(a'_1,a'_2,...,a'_n\)

假设每对舞伴的不协调程度分别是\(b'_1,b'_2,...,b'_n\)

令\(C=\frac{a'_1+a'_2+...+a'_n}{b'_1+b'_2+...+b'_n}\)

\(Cathy\)希望\(C\)值最大。

输入输出格式

输入格式:

第一行一个整数\(n\)。

接下来\(n\)行,每行\(n\)个整数,第\(i\)行第\(j\)个数表示\(a_{i,j}\)

接下来\(n\)行,每行\(n\)个整数,第i行第j个数表示\(b_{i,j}\)

输出格式:

一行一个数,表示\(C\)的最大值。四舍五入保留6位小数,选手输出的小数需要与标准输出相等。

说明

对于10%的数据, \(1≤n≤5\)

对于40%的数据, \(1≤n≤18\)

另有20%的数据, \(b_{i,j}≤1\)

对于100%的数据,\(a_{i,j},b_{i,j}<=10^4,1≤n≤100\)


做的第一道01分数规划的题。

01分数规划问题大多采用一种二分答案解法。

我们分数拆成整数,即

\(C*(b'_1+b'_2+...+b'_n)=a'_1+a'_2+...+a'_n\)

然后猜测一个\(C\)的值,检验在最优\(a,b\)配对的情况下左边与右边的大小关系,进而对\(C\)进行二分答案

如何求解最优配对呢?

再转化一下式子,左边-右边=

\(\sum_{i=1}^n (a'_i-b'_i*C)\)

我们要求解sum的最大值。

如果我们把对应点连上边\((a'_i-b'_i*C)\),就变成了跑 最大费用最大流或者 二分图带权匹配了

最后一点,这个题它卡常...


吸氧code:

#include <cstdio>
#include <cstring>
#include <queue>
using namespace std;
const int N=204;
const int inf=0x3f3f3f3f;
const double finf=1e100;
int a[N][N],b[N][N],n,used[N],pre[N];
double l=0.0,r=0.0,dis[N];
struct node
{
double c;
int from,to,next,w;
}edge[N*N];
int head[N],cnt=-1;
void add(int u,int v,double c,int w)
{
edge[++cnt].to=v;edge[cnt].from=u;edge[cnt].w=w;edge[cnt].c=c;edge[cnt].next=head[u];head[u]=cnt;
edge[++cnt].to=u;edge[cnt].from=v;edge[cnt].w=0;edge[cnt].c=-c;edge[cnt].next=head[v];head[v]=cnt;
}
queue <int > q;
bool spfa()
{
memset(used,0,sizeof(used));
memset(pre,0,sizeof(pre));
while(!q.empty()) q.pop();
for(int i=1;i<=2*n+1;i++) dis[i]=-finf;
dis[0]=0;
pre[0]=-1;
used[0]=1;
q.push(0);
while(!q.empty())
{
int u=q.front();
q.pop();
used[u]=0;
for(int i=head[u];i!=-1;i=edge[i].next)
{
int v=edge[i].to,w=edge[i].w;double c=edge[i].c;
if(w&&dis[u]+c>dis[v])
{
dis[v]=dis[u]+c;
pre[v]=i;
if(!used[v])
{
used[v]=1;
q.push(v);
}
}
}
}
return dis[2*n+1]!=-finf;
}
bool check(double L)
{
memset(head,-1,sizeof(head));
cnt=-1;
for(int i=1;i<=n;i++)
{
add(0,i,0,1);
add(i+n,2*n+1,0,1);
}
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
add(i,j+n,double(a[i][j])-double(b[i][j])*L,1);
double sum=0.0;
while(spfa())
{
int now=2*n+1;
while(pre[now]!=-1)
{
edge[pre[now]].w-=1;
edge[pre[now]^1].w+=1;
sum+=edge[pre[now]].c;
now=edge[pre[now]].from;
}
}
return sum<0.0;
} int main()
{
scanf("%d",&n);
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
{
scanf("%d",&a[i][j]);
r+=a[i][j];
}
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
scanf("%d",&b[i][j]);
while(l+1e-7<r)
{
double mid=(l+r)/2.0;
if(check(mid))
r=mid;
else
l=mid;
}
printf("%lf\n",l);
return 0;
}

2018.6.4

洛谷 P3705 [SDOI2017]新生舞会 解题报告的更多相关文章

  1. 洛谷3705 [SDOI2017] 新生舞会 【01分数规划】【KM算法】

    题目分析: 裸题.怀疑$ O(n^4log{n}) $跑不过,考虑Edmonds-Karp优化. 代码: #include<bits/stdc++.h> using namespace s ...

  2. 洛谷_Cx的故事_解题报告_第四题70

    1.并查集求最小生成树 Code: #include <stdio.h> #include <stdlib.h>   struct node {     long x,y,c; ...

  3. 洛谷 P2317 [HNOI2005]星际贸易 解题报告

    P2317 [HNOI2005]星际贸易 题目描述 输入输出格式 输入格式: 输出格式: 如果可以找到这样的方案,那么输出文件output.txt中包含两个整数X和Y.X表示贸易额,Y表示净利润并且两 ...

  4. 洛谷 P3802 小魔女帕琪 解题报告

    P3802 小魔女帕琪 题目背景 从前有一个聪明的小魔女帕琪,兴趣是狩猎吸血鬼. 帕琪能熟练使用七种属性(金.木.水.火.土.日.月)的魔法,除了能使用这么多种属性魔法外,她还能将两种以上属性组合,从 ...

  5. P3705 [SDOI2017]新生舞会 01分数规划+费用流

    $ \color{#0066ff}{ 题目描述 }$ 学校组织了一次新生舞会,Cathy作为经验丰富的老学姐,负责为同学们安排舞伴. 有\(n\)个男生和\(n\)个女生参加舞会买一个男生和一个女生一 ...

  6. 洛谷 P2606 [ZJOI2010]排列计数 解题报告

    P2606 [ZJOI2010]排列计数 题目描述 称一个\(1,2,...,N\)的排列\(P_1,P_2...,P_n\)是\(Magic\)的,当且仅当对所以的\(2<=i<=N\) ...

  7. 洛谷1303 A*B Problem 解题报告

    洛谷1303 A*B Problem 本题地址:http://www.luogu.org/problem/show?pid=1303 题目描述 求两数的积. 输入输出格式 输入格式: 两个数 输出格式 ...

  8. 洛谷 P3084 [USACO13OPEN]照片Photo 解题报告

    [USACO13OPEN]照片Photo 题目描述 农夫约翰决定给站在一条线上的\(N(1 \le N \le 200,000)\)头奶牛制作一张全家福照片,\(N\)头奶牛编号\(1\)到\(N\) ...

  9. 洛谷 P1379 八数码难题 解题报告

    P1379 八数码难题 题目描述 在3×3的棋盘上,摆有八个棋子,每个棋子上标有1至8的某一数字.棋盘中留有一个空格,空格用0来表示.空格周围的棋子可以移到空格中.要求解的问题是:给出一种初始布局(初 ...

随机推荐

  1. UML类图应该怎么看?

    学无止境,精益求精 十年河东,十年河西,莫欺少年穷 学历代表你的过去,能力代表你的现在,学习代表你的将来 我每次写博基本都是这样开头,除了激励自己,每句话也都挺有道理! 呵呵,今天是阴历2017年我工 ...

  2. Caffe源码中syncedmem文件分析

    Caffe源码(caffe version:09868ac , date: 2015.08.15)中有一些重要文件,这里介绍下syncedmem文件. 1.      include文件: (1).& ...

  3. ML.NET 示例:开篇

    写在前面 准备近期将微软的machinelearning-samples翻译成中文,水平有限,如有错漏,请大家多多指正. 如果有朋友对此感兴趣,可以加入我:https://github.com/fei ...

  4. 机器学习 第四篇:OLS回归分析

    变量之间存在着相关关系,比如,人的身高和体重之间存在着关系,一般来说,人高一些,体重要重一些,身高和体重之间存在的是不确定性的相关关系.回归分析是研究相关关系的一种数学工具,它能帮助我们从一个变量的取 ...

  5. [开源 .NET 跨平台 Crawler 数据采集 爬虫框架: DotnetSpider] [四] JSON数据解析

    [DotnetSpider 系列目录] 一.初衷与架构设计 二.基本使用 三.配置式爬虫 四.JSON数据解析与配置系统 五.如何做全站采集 场景模拟 接上一篇, JD SKU对应的店铺信息是异步加载 ...

  6. 虚拟机console基础环境配置——系统镜像站点配置

    1. 概述2. 部署HTTP服务器2.1 YUM安装httpd2.2 配置httpd2.3 启动httpdf2.4 测试httpd3. 部署FTP服务器3.1 YUM安装vsftpd3.2 配置vsf ...

  7. CSS 分类 (Classification) 实例

    CSS 分类 (Classification) 实例CSS 分类属性 (Classification)CSS 分类属性允许你控制如何显示元素,设置图像显示于另一元素中的何处,相对于其正常位置来定位元素 ...

  8. Haproxy和Nginx负载均衡测试效果对比记录

    为了对比Hproxy和Nginx负载均衡的效果,分别在测试机上(以下实验都是在单机上测试的,即负载机器和后端机器都在一台机器上)做了这两个负载均衡环境,并各自抓包分析.下面说下这两种负载均衡环境下抓包 ...

  9. IDEA启动服务阻塞,断点过程十分慢的问题

    使用debug无法启动项目但是使用run就可以启动程序,而且启动比以前的debug模式快的多 原因: 启动不了的原因是在项目中的方法上打了断点,导致项目无法继续编译 取消方法断点就可以了 在idea官 ...

  10. PHP使用echo输出标签设置CSS样式问题

    使用php是可以输出HTML标签的,这为页面设计带来很大方便. 在此记录php输出标签设置CSS样式的问题: echo可使用''.""或你不用引号,如果想要输出带CSS样式的HTM ...