CF1098D 题解
题意
对于一个元素个数大于 \(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 题解的更多相关文章
- 2016 华南师大ACM校赛 SCNUCPC 非官方题解
我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...
- noip2016十连测题解
以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...
- BZOJ-2561-最小生成树 题解(最小割)
2561: 最小生成树(题解) Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1628 Solved: 786 传送门:http://www.lyd ...
- Codeforces Round #353 (Div. 2) ABCDE 题解 python
Problems # Name A Infinite Sequence standard input/output 1 s, 256 MB x3509 B Restoring P ...
- 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解
题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...
- 2016ACM青岛区域赛题解
A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Jav ...
- poj1399 hoj1037 Direct Visibility 题解 (宽搜)
http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...
- 网络流n题 题解
学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...
- CF100965C题解..
求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...
- JSOI2016R3 瞎BB题解
题意请看absi大爷的blog http://absi2011.is-programmer.com/posts/200920.html http://absi2011.is-programmer.co ...
随机推荐
- 【转载】github.com访问慢解决办法
打开网站 IPAddress.com ,找到页面中下方的"IP Address Tools – Quick Links" 分别输入github.global.ssl.fastly. ...
- 【转载】WebBrowser控件的常用方法、属性和事件
1. 属性 属性 说明 Application 如果该对象有效,则返回掌管WebBrowser控件的应用程序实现的自动化对象(IDispatch).如果在宿主对象中自动化对象无效,这个程序将返回Web ...
- Triple 协议支持 Java 异常回传的设计与实现
作者:Apache Dubbo Contributor 陈景明 背景 在一些业务场景, 往往需要自定义异常来满足特定的业务, 主流用法是在catch里抛出异常, 例如: public void dea ...
- [OpenCV实战]1 基于深度学习识别人脸性别和年龄
目录 1基于CNN的性别分类建模原理 1.1 人脸识别 1.2 性别预测 1.3 年龄预测 1.4 结果 2 代码 参考 本教程中,我们将讨论应用于面部的深层学习的有趣应用.我们将估计年龄,并从单个图 ...
- python之路45 初识django框架
纯手撸web框架 1.web框架的本质 理解1:连接前端与数据库的中间介质 理解2:socket服务端 2.手写web框架 1.编写socket服务端代码 2.浏览器访问响应无效>>> ...
- [剑指Offer]3.数组中重复的数字
题目 找出数组中重复的数字. 在一个长度为n的数组中的所有数字都在0~n-1的范围内.数组中某些数字是重复的,但是不知道有几个数字重复了,也不知道每个数字重复了几次.请找出数组中任意一个重复的数组.例 ...
- CSP/S 2022 游寄
初赛 HN 初赛分数线好像大 \(32\) 分左右,通过率极高!本人弱弱的拿了 \(60.5\) 分(周围的同学平均分 \(>80\).) Day -1 这一天晚上,我背了背 dijkstra, ...
- win32com操作word API精讲&项目实战 预告
对win32com的使用和研究有好一段时间了,想起本人刚开始做word编程项目时的各种痛苦:网上能找到的都是简单的示例,如同hello word一般,嚼之无味又无可奈何.读office的word接口文 ...
- ES6 01 简介
1 记录一个好的笔记 一个非常详细的笔记:https://es6.ruanyifeng.com/#docs/intro 2 简介 2.1 ECMAScript 和 JavaScript ECMAScr ...
- 断点调试/认证/权限/频率-源码分析/基于APIView编写分页/异常处理
内容概要 断点调试 认证/权限/频率-源码分析 基于APIView编写分页 异常处理 断点调试 # 程序以 debug模式运行,可以在任意位置停下,查看当前情况下变量数据的变化情况 # pycharm ...