CodeForces 1098D. Eels
题目简述:对一个非空正整数(可重)集合$S$,从中选出两个元素$a, b (a \leq b)$,将他们从$S$中删除并将$a+b$加入$S$,重复这个操作直到$S$中只剩下一个元素为止,称为一次【竞技】。若一次操作中$a \leq b \leq 2a$,则称这次操作是【危险的】。一次竞技的【危险值】为其中【危险的】操作的次数。定义这个集合$S$的【危险值】(记作$\text{danger}(S)$)为:所有可能的竞技的【危险值】的最大值。设一个集合$S$初始为空集,维护以下操作:
1. 插入一个数$1 \leq x \leq 10^9$。
2. 删除一个(已有的)数$1 \leq x \leq 10^9$。
每次操作后,计算$\text{danger}(S)$。
解:code
对$x \in S$,定义$S$中比$x$小的数之和为
$$ f(x) = \sum_{a \in S, a < x} a. $$
定义$x$的等级为
$$ g(x) = \max_{a \in S, a < x} \{ g(a) \} + [2f(x)<x], $$
特别地,$\max \emptyset = 0$。
令$S$中的最高等级为
$$t = \max_{x \in S} \{ g(x) \}. $$
观察0:若$x < y$,则$ g(x) \leq g(y) \leq g(x)+1 $。
观察1:$\text{danger}(S)=|S|-t$。
证明:
先证$\text{danger}(S) \leq |S|-t$。令$T = \{ (x, g(x)): x \in S \}$,则$S$中的一次操作
【从$S$中取出两个元素$a$和$b$,并把$a+b$插入$S$。】
可对应为$T$的一次操作:
【从$T$中取出两个元素$(a, x)$和$(b, y)$,并把$(a+b, \max\{x,y\})$插入$T$。】
于是$S$的一次竞技,可对应$T$的一次竞技。
注意到,若$T$中的一次操作有$x = y$,则称这次操作是【不安全的】。$S$的任何一次不【危险的】操作,在$T$中都不是【不安全的】。$T$中一次竞技的【不安全值】为其中【不安全的】操作的次数。定义$T$的【不安全值】为所有可能的竞技的不安全值的最大值,记作$\text{unsafe}(T)$。则显然有$\text{danger}(S) \leq \text{unsafe}(T)$。
另一方面,$T$的任意一个可能的竞技中,都会导致竞技的结果剩下$(\sum_{a \in S} a, \max_{a \in S} \{ g(a) \})$,又至少有$t-1$次操作有$x \neq y$,从而$\text{unsafe}(T) \leq (|T|-1)-(t-1) = |T|-t$,即$\text{danger}(S) \leq |S|-t$。
再证$\text{danger}(S) \geq |S|-t$。我们只需给出一个竞技策略,即每次操作是从$S$中取出最小的两个元素$a$和$b$,并把$a+b$插入$S$。假设在某次操作$a$和$b$($a \leq b$)的不【危险的】,即$2a<b$,则$b$不曾被合并过(或者说$b$是$S$的原始元素),不然设$b = c+d$其中$c \leq d$,则$d \geq b/2 > a$,这说明$d$在$a$之前参与了某次合并操作,这与我们的竞技策略矛盾。这个竞技策略会导致,每种不同等级的元素中,恰好有一个(这个等级中某个最小的元素)参与了不【危险的】操作,从而这个竞技的【危险值】为$|S|-t$。故$\text{danger}(S) \geq |S|-t$。
综上,有$\text{danger}(S)=|S|-t$。
QED
因此,我们把$\text{danger}(S)$的计算转化为求$S$中元素的最高等级$t$。
观察2:$g(x) \leq \log_2 x + 1$,从而$t \leq \log_2 V+1$,其中$V = \max_{x \in S} \{x\}$。(数学归纳法)
我们将元素的取值范围划分为$[1, 2), [2, 4), [4, 8), \dots, [2^{k}, 2^{k+1}), \dots, [2^{29}, 2^{30})$。
观察3:在$[2^{k}, 2^{k+1})$范围内的至多存在一个$x \in [2^{k}, 2^{k+1})$,使得$g(y) < g(x)$对任意$y < x$成立。若存在这样的$x$,则$x$必为$[2^{k}, 2^{k+1})$中的最小值,且$2f(x)<x$。$t$等于满足这个条件的$x$的个数。
于是对每个$k = 0, 1, 2, \dots, 29$,维护容器$H[k]$,在插入(或删除)一个元素$x$时,若$x \in [2^{k}, 2^{k+1})$,则把$x$插入(或删除自)$H[k]$。对计算$\text{danger}(S)$,只需统计满足【观察3】的条件的$x$的个数。可用multiset来维护$H[k]$。
一共需要维护$O(\log V)$个multiset,从而时间复杂度为$O(Q \log Q \log V)$,其中$Q$为询问次数,$V$为所有元素的最大值。
CodeForces 1098D. Eels的更多相关文章
- Codeforces VP/补题小记 (持续填坑)
Codeforces VP/补题小记 1149 C. Tree Generator 给你一棵树的括号序列,每次交换两个括号,维护每次交换之后的直径. 考虑括号序列维护树的路径信息和,是将左括号看做 ...
- python爬虫学习(5) —— 扒一下codeforces题面
上一次我们拿学校的URP做了个小小的demo.... 其实我们还可以把每个学生的证件照爬下来做成一个证件照校花校草评比 另外也可以写一个物理实验自动选课... 但是出于多种原因,,还是绕开这些敏感话题 ...
- 【Codeforces 738D】Sea Battle(贪心)
http://codeforces.com/contest/738/problem/D Galya is playing one-dimensional Sea Battle on a 1 × n g ...
- 【Codeforces 738C】Road to Cinema
http://codeforces.com/contest/738/problem/C Vasya is currently at a car rental service, and he wants ...
- 【Codeforces 738A】Interview with Oleg
http://codeforces.com/contest/738/problem/A Polycarp has interviewed Oleg and has written the interv ...
- CodeForces - 662A Gambling Nim
http://codeforces.com/problemset/problem/662/A 题目大意: 给定n(n <= 500000)张卡片,每张卡片的两个面都写有数字,每个面都有0.5的概 ...
- CodeForces - 274B Zero Tree
http://codeforces.com/problemset/problem/274/B 题目大意: 给定你一颗树,每个点上有权值. 现在你每次取出这颗树的一颗子树(即点集和边集均是原图的子集的连 ...
- CodeForces - 261B Maxim and Restaurant
http://codeforces.com/problemset/problem/261/B 题目大意:给定n个数a1-an(n<=50,ai<=50),随机打乱后,记Si=a1+a2+a ...
- CodeForces - 696B Puzzles
http://codeforces.com/problemset/problem/696/B 题目大意: 这是一颗有n个点的树,你从根开始游走,每当你第一次到达一个点时,把这个点的权记为(你已经到过不 ...
随机推荐
- php实现类似淘宝最近浏览商品的功能模型代码
<?php //TempNum 显示临时记录数 $TempNum=5; //setcookie("RecentlyGoods", "12,31,90,39" ...
- 【转】VMware 11.0 简体中文版|附永久密钥
VMware 11.0 简体中文版|附永久密钥 昨天,VMware虚拟机11.0 简体中文版正式发布,值得注意的是新版抛弃了32位系统支持,安装包体积大幅减小, 新增Windows 10 技术预览版支 ...
- python--面向对象—接口
开放封闭原则依赖导致原则接口隔离原则继承多态抽象类和接口类 编程思想:为子类做规范 归一化设计:几个类都实现了相同的方法 抽象类:最好单继承,且可以简单的实现功能 接口类:可以多继承,且最好不实 ...
- kubernetes调度之污点(taint)和容忍(toleration)
系列目录 节点亲和性(affinity),是节点的一种属性,让符合条件的pod亲附于它(倾向于或者硬性要求).污点是一种相反的行为,它会使pod抗拒此节点(即pod调度的时候不被调度到此节点) 污点和 ...
- 高性能MySQL(二)
MySQL基准测试 为什么需要benchmark 验证基于系统的假设,确认是否符合实际情况 重现系统中的某些异常行为,以解决它们 测试系统当前的运行情况,如果不清楚当前性能,就无法确认优化效果 模拟比 ...
- return和exit的差别
#include<stdio.h> #include<sys/types.h> #include<sys/wait.h> #include<unistd.h& ...
- 使用C#解决部分Win8.1系统窗体每隔几秒失去焦点的问题
使用了Win8.1 With Update 1后,发现重新启动系统后,当前激活的窗体总是每隔几秒失去焦点.过0.5~1秒焦点回来.导致输入无法正常工作,严重影响使用心情和效率. 在网上找了非常久,也没 ...
- EasyDarwin开源流媒体音视频云平台遇到的奇葩问题:内网运行正常,公网流媒体不通
最近在帮助EasyDarwin的用户部署EasyNVR+EasyDarwin云平台+EasyClient方案的过程中,遇到一个问题,EasyNVR分布在用户各地区现场的内网中,EasyDarwin云平 ...
- Latex强制图片位置
经常使用选项[htbp]是浮动格式: 『h』当前位置.将图形放置在正文文本中给出该图形环境的地方. 假设本页所剩的页面不够.这一參数将不起作用. 『t』顶部.将图形放置在页面的顶部. 『b』底部.将图 ...
- Mongoose学习(1)
1.Schema : 一种以文件形式存储的数据库模型骨架,不具备数据库的操作能力 Model : 由Schema发布生成的模型,具有抽象属性和行为的数据库操作对 Entity : 由Mod ...