题意

传送门

对于一个元素个数大于 \(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. 正则提取器和beanshell处理器组合,将提取的所有id拼接成字符串

    1.添加正则表达式,提取所有id值 2.添加beanshell处理器将所有的id值拼接成字符串 方法一: int N = Integer.parseInt(vars.get("build_m ...

  2. JVM常用调优参数

    目录 JVM内存模型及常用参数 参数解释 垃圾收集器 Serial收集器(-XX:+UseSerialGC -XX:+UseSerialOldGC) Parallel Scavenge收集器(-XX: ...

  3. des_招标

    网站 aHR0cHM6Ly9jdGJwc3AuY29tLyMv 翻到第二页,加载了一个2,并且返回的都是加密的数据  点到initiator,可以看到发送的Axios请求,尝试全局搜索intercep ...

  4. 使用Springboot+redis+Vue实现秒杀的一个Demo

    目录 1.Redis简介 2.实现代码 3.启动步骤 4.使用ab进行并发测试 5.线程安全 6.总结 7.参考资料 1.Redis简介 Redis是一个开源的key-value存储系统. Redis ...

  5. [python]《Python编程快速上手:让繁琐工作自动化》学习笔记5

    1. 处理CSV文件笔记(第14章) (代码下载) 本文主要在python下介绍CSV文件,CSV 表示"Comma-Separated Values(逗号分隔的值)",CSV文件 ...

  6. [python]《Python编程快速上手:让繁琐工作自动化》学习笔记3

    1. 组织文件笔记(第9章)(代码下载) 1.1 文件与文件路径 通过import shutil调用shutil模块操作目录,shutil模块能够在Python 程序中实现文件复制.移动.改名和删除: ...

  7. .NET周报【1月第1期 2023-01-06】

    国内文章 [开源]基于.net6+gtksharp实现的Linux下的图形界面串口调试工具 https://www.cnblogs.com/flykai/p/17007554.html 由于公司的上位 ...

  8. NetCore模型绑定之FromBodyFromUriFromQueryFromRoute

    title: .Net Core模型绑定之FromBody.FromUri.FromQuery.FromRoute categories: 后端 date: 2022-10-29 17:21:11 t ...

  9. Android Volley 基本使用

    Android Volley 基本使用 本篇主要介绍 Google 给Android 平台提供的 Volley 一个 Http请求库 , 齐射! 1.概述 Volley是Google 提供的一个小巧的 ...

  10. P8701 [蓝桥杯 2019 国 B] 第八大奇迹

    简要题意 你需要维护一个长度为 \(L\) 的序列 \(a\),初始时全部都是 \(0\),有 \(N\) 个操作,支持: C p x,将 \(a_p\) 修改为 \(x\). Q a b,输出 \( ...