【BZOJ4030】[HEOI2015]小L的白日梦

题面

BZOJ

洛谷

题解

要求的是最小的不开心连续段的期望。

然后发现自己就不会做了。

然后就可以来抄题解啦。

首先来猜性质:

  • 第一个,一定是按照不高兴的概率单调不增的一个序列。

    还是比较容易猜到的,这个证明也不难,首先我们把这个期望的式子给列出来,发现是:

\[E=\sum_{i=1}^n (1-a_{i-1})a_i
\]

也就是强制在每一段的开头位置统计,那么这个位置必定满足前一天是开心的,且这一天是不开心的。并且因为是单调的,所以满足\(a_i\ge a_{i+1}\)。

现在假设把某两个位置交换,假设这两个位置是\(i,j\),且\(i<j\),那么:

\[\begin{aligned}\Delta=&(1-a_{i-1})a_i+(1-a_i)a_{i+1}+(1-a_{j-1})a_j+(1-a_j)a_{j+1}\\
&-(1-a_{i-1})a_j-(1-a_j)a_{i+1}-(1-a_{j-1})a_i-(1-a_i)a_{j+1}\\
=&(1-a_{i-1})(a_i-a_j)+(1-a_i)(a_{i+1}-a_{j+1})\\
&+(1-a_{j-1})(a_j-a_i)+(1-a_j)(a_{j+1}-a_{i+1})\\
=&(a_i-a_j)(a_{j-1}-a_{i-1})+(a_{i+1}-a_{j+1})(a_j-a_i)\\
=&(a_i-a_j)(a_{j-1}+a_{j+1}-a_{i-1}-a_{i+1})
\end{aligned}\]

显然\(\Delta=E-E'<0\),所以有\(E<E'\),所以就证明了如果序列是单调不增的话期望是最小的。

  • 第二个结论:选择的一定是按照概率排序之后的一段前缀和一段后缀。

    我一开始猜的以为一定是前缀......

    假设我们选择的是一段前缀\([1,i]\),一段后缀\([j,n]\)。当然都是按照从大往小的顺序排序之后的结果。然后不考虑在中间选择了一段,考虑在中间选择了一个会怎么样,假设在两次选择中,在中间选择了\(x\)和\(y\),\(x<y\)。

    那么两者的期望的变化量分别是:

\[\begin{aligned}
\Delta&=(1-a_i)a_x+(1-a_x)a_j-(1-a_i)a_y+(1-a_y)a_j\\
&=(1-a_i)(a_x-a_y)+a_j(a_y-a_x)\\
&=(a_x-a_y)(1-a_i-a_j)
\end{aligned}\]

发现\((1-a_i-a_j)\)是定值,那么讨论一下,如果它大于\(0\),那么\((a_x-a_y)\)一定是越小越好,所以会尽可能靠向\(j\),反过来一定靠向\(i\)。那么既然都尽可能靠向了,那么就直接放在一起好啦。

  • 第三个性质:每个东西要么选\(1\)个,要么全部选掉。除了这两种情况之外的情况最多只可能出现一次。

    首先假装我们不知道这个东西,考虑怎么做,我们可以预处理前缀和后缀的最大贡献,然后枚举一个前缀的端点,那么对于所有后缀而言,找一个最大的贡献就行了。

    但是这样子做不了\(1e9\),因为你需要枚举端点的确切位置。

    现在我们来考虑这个性质怎么处理,首先没有选完整的最多只会有两块,即前缀的最后一段和后缀的最靠前的一段。

    那么我们这么考虑,假设后缀的最靠前的一段多出来了若干个,那么如果把一个变成前缀的最后一个的变化量是\(\Delta\),那么丢到这一段只剩一个之前,每次往前丢一个贡献都是\(\Delta\),这个很显然。所以可以把后缀的这一段变得只剩一个,然后就符合上面的情况了。

具体实现我也是抄代码了QwQ。

#include<iostream>
#include<cstdio>
#include<cmath>
#include<algorithm>
using namespace std;
#define MAX 100100
#define double long double
const double eps=1e-10;
inline int read()
{
int x=0;bool t=false;char ch=getchar();
while((ch<'0'||ch>'9')&&ch!='-')ch=getchar();
if(ch=='-')t=true,ch=getchar();
while(ch<='9'&&ch>='0')x=x*10+ch-48,ch=getchar();
return t?-x:x;
}
struct Node{double p;int c;}p[MAX];
bool cmp(Node a,Node b){return a.p>b.p;}
int n,K;
int main()
{
int T=read();
while(T--)
{
n=read();K=read();
for(int i=1;i<=n;++i)
{
int x=read(),y=read();
p[i].p=1.0*x/y,p[i].c=read();
}
sort(&p[1],&p[n+1],cmp);
int l=1,r=n,t;
while(!p[l].c)++l;while(!p[r].c)--r;
p[l].c-=1;p[r].c-=1;K-=2;
double pl=p[l].p,pr=p[r].p;
double ans=0;
while(K)
{
while(!p[l].c)++l;
while(!p[r].c)--r;
if(1-pl>pr)
{
if(fabs(pr-p[r].p)>eps)t=1;
else t=min(K,p[r].c);
ans+=(1-p[r].p)*pr+(t-1)*(1-p[r].p)*p[r].p;
K-=t;p[r].c-=t;pr=p[r].p;
}
else
{
if(fabs(pl-p[l].p)>eps)t=1;
else t=min(K,p[l].c);
ans+=(1-pl)*p[l].p+(t-1)*(1-p[l].p)*p[l].p;
K-=t;p[l].c-=t;pl=p[l].p;
}
}
ans+=(1-pl)*pr;
printf("%.6Lf\n",ans);
}
return 0;
}

【BZOJ4030】[HEOI2015]小L的白日梦的更多相关文章

  1. BZOJ 4030: [HEOI2015]小L的白日梦

    4030: [HEOI2015]小L的白日梦 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 172  Solved: 39[Submit][Statu ...

  2. HEOI2015小L的白日梦

    题面链接 洛咕 sol 为什么网上面只有神仙题解啊!!! 引起我这种蒟蒻不适QAQ. 性质证明留给巨佬 然后我只贴性质了QwQ. 1.一定存在最优解每一天不高兴的概率是单调不增的. 2.一定存在最优解 ...

  3. P4110 [HEOI2015]小L的白日梦

    传送门 题解 //minamoto #include<bits/stdc++.h> using namespace std; typedef long long ll; typedef l ...

  4. bzoj4030【HEOI2015】小L的白日梦

    题意:http://www.lydsy.com/JudgeOnline/problem.php?id=4030 sol  :orz Yousiki http://www.cnblogs.com/you ...

  5. 洛谷U4727小L的二叉树[树转序列 LIS]

    题目背景 勤奋又善于思考的小L接触了信息学竞赛,开始的学习十分顺利.但是,小L对数据结构的掌握实在十分渣渣. 所以,小L当时卡在了二叉树. 题目描述 在计算机科学中,二叉树是每个结点最多有两个子结点的 ...

  6. ACM D的小L

    D的小L 时间限制:4000 ms  |  内存限制:65535 KB 难度:2   描述       一天TC的匡匡找ACM的小L玩三国杀,但是这会小L忙着哩,不想和匡匡玩但又怕匡匡生气,这时小L给 ...

  7. bzoj 4031: [HEOI2015]小Z的房间 轮廓线dp

    4031: [HEOI2015]小Z的房间 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 98  Solved: 29[Submit][Status] ...

  8. nyoj-366-D的小L(求全排列)

    D的小L 时间限制:4000 ms  |  内存限制:65535 KB 难度:2 描述       一天TC的匡匡找ACM的小L玩三国杀,但是这会小L忙着哩,不想和匡匡玩但又怕匡匡生气,这时小L给匡匡 ...

  9. 洛谷U4727 小L 的二叉树

    U4727 小L 的二叉树 题目背景 勤奋又善于思考的小L接触了信息学竞赛,开始的学习十分顺利.但是,小L对数据结构的掌握实在十分渣渣. 所以,小L当时卡在了二叉树. 题目描述 在计算机科学中,二叉树 ...

随机推荐

  1. Ambiguous HTTP method Actions require an explicit HttpMethod binding for Swagger 2.0

    异常内容 NotSupportedException: Ambiguous HTTP method for action . Actions require an explicit HttpMetho ...

  2. 简述ADO.NET的连接层

    前面曾提到过ADO.NET的连接层允许通过数据提供程序的连接.命令.数据读取器对象与数据库进行交互.当想连接数据库并且使用一个数据读取器对象来读取数据时.需要实现下面的几个步骤 * 创建.配置.打开连 ...

  3. DevExpress AspxGridView分页使用隐藏系统默认英文分页

    1第一篇文章研究了怎么汉化,但是在实际使用过程中发现汉化的有小问题,DevExpress支持自定义按钮,也可以在属性中设置成中文,这样避免汉化不准确的问题 <dx:ASPxGridView ID ...

  4. Spring-注解实现IOC

    一.定义 注解:是一种标记式的配置方式,与XML配置文件不同,注解提供了更大的便捷性,易于维护修改,但是耦合度高. 本质:是一个继承了 Annotation 接口的接口,注解本身并没有什么作用,通过特 ...

  5. SpringMVC+Spring+Mybatis整合

    SpringMVC+Spring+Mybatis整合 导包 配置jdbc.properties.log4j.properties jdbc.driver=com.mysql.jdbc.Driver j ...

  6. PHP一些常用的正则表达式分享给大家

    一.校验数字的表达式 1 数字:^[0-9]*$2 n位的数字:^\d{n}$3 至少n位的数字:^\d{n,}$4 m-n位的数字:^\d{m,n}$5 零和非零开头的数字:^(0|[1-9][0- ...

  7. Add In 简介(主要翻译于ESRI官方文档)

    为ArcGIS桌面端建立Add In插件 平时以工作为主,有空时翻译一些文档,顺便练习英文,这个是因为用Add In来学习一下. 主要包括: 关于Add In 什么时候使用Add In Python ...

  8. 【设计模式】组合模式 Composite Pattern

    树形结构是软件行业很常见的一种结构,几乎随处可见,  比如: HTML 页面中的DOM,产品的分类,通常一些应用或网站的菜单,Windows Form 中的控件继承关系,Android中的View继承 ...

  9. (七) Keras 绘制网络结构和cpu,gpu切换

    视频学习来源 https://www.bilibili.com/video/av40787141?from=search&seid=17003307842787199553 笔记 首先安装py ...

  10. vue 导出xlsx表功能

    详细步骤: 1.需要安装三个依赖: npm install -S file-saver xlsx npm install -D script-loader 两个命令行包含三个依赖. 2.项目中src下 ...