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 ...
随机推荐
- 二阶段目标检测网络-Cascade RCNN 详解
摘要 1,介绍 1.1,Faster RCNN 回顾 1.2,mismatch 问题 2,实验分析 2.1,改变IoU阈值对Detector性能的影响 2.2,提高IoU阈值的影响 2.3,和Iter ...
- snprintf拼接字符串
例如编辑一个txt文档,不断将字符输入,最终形成一个长句子.可以看成是字符串的不断拼接.snprintf函数具有这个功能. #include<stdio.h> void main(void ...
- [OpenCV实战]52 在OpenCV中使用颜色直方图
颜色直方图是一种常见的图像特征,顾名思义颜色直方图就是用来反映图像颜色组成分布的直方图.颜色直方图的横轴表示像素值或像素值范围,纵轴表示该像素值范围内像素点的个数或出现频率.颜色直方图属于计算机视觉中 ...
- [深度学习] ncnn安装和调用基础教程
目录 1 介绍 2 Ubuntu 18下ncnn安装和使用 2.1 Ubuntu 18下ncnn编译安装 2.2 Ubuntu 18下ncnn使用 3 Windows 10下ncnn安装和使用 3.1 ...
- Hive详解(05) - 压缩和存储
Hive详解(05) - 压缩和存储 Hadoop压缩配置 MR支持的压缩编码 压缩格式 算法 文件扩展名 是否可切分 DEFLATE DEFLATE .deflate 否 Gzip DEFLATE ...
- [LeetCode]杨辉三角 II
题目 代码 class Solution { public: vector<int> getRow(int rowIndex) { vector<int> array(rowI ...
- Spring MVC复习 —— 搭建Spring MVC项目
Spring MVC复习 -- 搭建Spring MVC项目 摘要:这篇笔记是关于Spring MVC的复习,内容是如何搭建Spring MVC项目. 让我们快速的搭建一个Spring MVC ...
- Runloop的使用
系统为我们提供了多种模式,下面列一些比较常遇到的: kCFRunLoopDefaultMode: App的默认 Mode,通常主线程是在这个 Mode 下运行的. UITrackingRunLoopM ...
- angular 父组件调用子组件方法---以及组件跨模块使用方法
如果要在父组件调用子组件 可以这样子 @ViewChild('mySun', { static: false }) mySun: MySunComponent; 使用方法: let res=this. ...
- (补12月19)ORM查询优化、ORM事物操作、ORM常用字段参数、Ajax请求、Content-Type
ORM查询优化.ORM事物操作.ORM常用字段参数.Ajax请求.Content-Type Q查询进阶操作 先产生一个对象 q_obj = Q() 修改默认对象 q_obj.connector = ' ...