题意

传送门

对于一个元素个数大于 \(1\) 的可重集,每次取出两个数 \(x,y\) 合并。若 \(x\le y\le 2x\),则称其为危险合并。重复上述操作至无法合并。

给你一个初始为空的可重集与 \(n\) 次操作,每次加入或删除一个数,求每次操作后最大的危险合并次数。

\(1\le n \le5\times10^5,1\le x\le10^9\)。

题解

这题太妙了。深深感觉自己的弱小……

首先我们证明一个结论:每次取最小的两个数合并,可以取得最大的危险合并次数。方便起见,称 \(x,y\) 是危险合并为 \(x,y\) 合法。

设最小两值为 \(a,b\)。若不合并 \(a,b\),那么 \(a,b\) 中先与其他数合并的那个,不妨设为 \(b\)。考虑 \(b,c\) 合并,其中 \(c\geq b\):

  • 若 \(b,c\) 合法。若 \(a+b\le c\),则显然 \(a+b,c\) 合法。若 \(a+b>c\),由 \(a\le c,b\le c\),有 \(a+b\le2c\),则 \(a+b,c\) 也合法。那么贪心先合并 \(a,b\)。
  • 若 \(b,c\) 不合法。因为 \(2b<c\),所以 \(a+b<c\)。显然先合并 \(a,b\) 不会更劣。

于是不带修直接用小根堆即可。那么带修呢?

再证明一个结论:若最小二值 \(a,b\) 合法,则接下来的所有合并 \(x,y\),若 \(x,y\in[b,a+b]\),则 \(x,y\) 合法。

证明很简单,\(y\le2x\iff y-x\le x\),因为 \(y-x\le a\),故成立。有了这个结论,我们可以做很多事。

我们可以证明,将初始元素升序排序后,合法合并一定是一段段的。如下(图片来自 \(\texttt{lzqy_}\))

且所有不合法合并一定是形如 \(2\sum\limits_{i=1}^{x-1}a_i<a_{x}\)。于是我们就将原来动态的合并转化为了静态问题。

按值域分块,\([2^0,2^1),[2^1,2^2)\cdots[2^{29},2^{30})\)。则每块内只有第一个元素可能非法。逐块判断即可。复杂度 \(O(n\log x)\)。

CF1098D 题解的更多相关文章

  1. 2016 华南师大ACM校赛 SCNUCPC 非官方题解

    我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...

  2. noip2016十连测题解

    以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...

  3. BZOJ-2561-最小生成树 题解(最小割)

    2561: 最小生成树(题解) Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1628  Solved: 786 传送门:http://www.lyd ...

  4. Codeforces Round #353 (Div. 2) ABCDE 题解 python

    Problems     # Name     A Infinite Sequence standard input/output 1 s, 256 MB    x3509 B Restoring P ...

  5. 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解

    题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...

  6. 2016ACM青岛区域赛题解

    A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Jav ...

  7. poj1399 hoj1037 Direct Visibility 题解 (宽搜)

    http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...

  8. 网络流n题 题解

    学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...

  9. CF100965C题解..

    求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...

  10. JSOI2016R3 瞎BB题解

    题意请看absi大爷的blog http://absi2011.is-programmer.com/posts/200920.html http://absi2011.is-programmer.co ...

随机推荐

  1. [0x11] 130.火车进站问题【卡特兰数】

    题意 link(more:129.,P1044) 简化题意:给定严格从 \(1\thicksim n\) 这 \(n(n\leqslant 6\times10^4)\) 个整数,规定每个数都要进出栈各 ...

  2. MongoDB - 副本集简介

    简介 在 MongoDB 中,副本集指的是一组 MongoDB 服务器实例掌管同一个数据集,实例可以在不同的机器上. 其中一个用于处理写操作的是主节点(Primary),还有多个用于保存主节点的数据副 ...

  3. anaconda peompt 、labalimg 数据标注

    安装anaconda,进行数据标注 1.安装前准备:下好安装包和所需文件 https://www.aliyundrive.com/s/XyH2JQ5TjCz 提取码: 3c2w 2.运行anacond ...

  4. [图像处理] YUV图像处理入门5

    12 yuv420转换为rgb(opencv mat) yuv格式具有亮度信息和色彩信息分离的特点,但大多数图像处理操作都是基于RGB格式,而且自己造轮子工作量太大.因此通常都会将yuv转换为rgb, ...

  5. Jasypt与Apollo一起使用造成Apollo热更新失效问题分析

    背景 近日业务同学反映在Apollo界面更改配置后, 服务中对应变量的值却没有改变 相关配置key定义如下: @ApolloJsonValue("${apollo.config.map:{} ...

  6. [WPF]项目整合Metro和MaterialDesignInXamlToolkit UI框架

    项目地址 MapApps:Metro MaterialDesignInXamlToolkit:MaterialDesignInXamlToolkit MapApps官网:官网链接 官方整合文档 官方提 ...

  7. (19)go-micro微服务filebeat收集日志

    目录 一 Filebeat介绍 二 FileBeat基本组成 三 FileBeat工作原理 四 Filebeat如何记录文件状态: 五 Filebeat如何保证事件至少被输出一次 六 安装Filebe ...

  8. DDL_操作数据库_修改&删除&使用

    DDL_操作数据库_修改&删除&使用 3.U(Update) : 修改 修改数据库的字符集 alter database 数据库名称 character set 字符集名称; 4.D( ...

  9. 结构型模式 - 桥接模式Bridge

    学习而来,代码是自己敲的.也有些自己的理解在里边,有问题希望大家指出. 桥接模式的定义与特点 桥接(Bridge)模式的定义如下:将抽象与实现分离,使它们可以独立变化.它是用组合关系代替继承关系来实现 ...

  10. 最容易懂的策略模式消除if-else分支,实现开闭原则,提高可扩展性

    1 介绍 策略模式最常用的场景就是用于消除代码中的if-else,这里所说的if-else并不是说任何简单的判断都引入策略模式来优化,这样反而会增加代码的复杂度. 反例:使用策略模式对一个boolea ...