请问您今天要来点 ODT 吗
梗出处:请问您今天要来点兔子吗?
这篇文章主要记录一下自己学习 \(\text{ODT}\) 发生的种种。
CF896C Willem, Chtholly and Seniorious
\(\text{ODT}\) 成名题目,表示 \(\text{lxl}\) 为了防 \(\text{Hack}\) 真的是用心了。
关于 \(\text{ODT}\) 随机情况下的期望时间复杂度,请参考著名某知乎文章。
很暴力的数据结构,assign
操作是核心,剩下的基本上都是暴力区间分离,暴力统计联通区间。
期望时间复杂度 \(\Theta(n \log \log n)\)
P4979 矿洞:坍塌
为数不多 \(\text{ODT}\) 的时间复杂度是正确的题目?
只能说 \(\text{Hack}\) 数据卡了个寂寞。
有一种更加优秀的做法,但是我没想,所以下面给出一个不是很优秀的做法(也可以当做一种 \(trick\))
发现一共两个操作,一个是 assign
操作,另一个是 query
。
考虑时间复杂度最有可能会被摊到哪里,发现是我们亲爱的 query
操作。
因为 assign
操作可能会产生大量的散块,所以我们可以考虑在 query
的时候,对于当前同颜色联通的散块进行一次 assign
,然后如果发现当前不合法了 break
维护再跳出,可以看出,这样摊下来时间复杂度会被摊到 \(O(n \log n)\)。
估计这可能也是它评蓝的原因
CF915E Physical Education Lessons
一开始脑瘫了,真的就按照题目给出的条件去硬 query
了。
发现如果硬 query
很容易被卡掉。
所以考虑修改带来的影响,发现每次修改都是 assign
操作,所以就考虑课程数的变化量 \(\Delta\) 就可以了。
然后……就做完了,时间复杂度感觉有点抽象,不是很懂。
P5066 [Ynoi2014] 人人本着正义之名
感觉这个题 \(\text{ODT}\) 很逆天,所以显然只能拿 \(80\) pts。
首先看题,是 \(01\) 序列。
然后发现,两个 assign
,一个区间和,还有四个抽象的操作。
考虑那四个抽象的操作是什么:
- 相邻按位与:\(0\) 向相邻方向吞一个。
- 相邻按位或:\(1\) 向相邻方向吞一个。
然后……就是 \(ODT\) 维护了。
当然,正解是平衡树。
CF817F MEX Queries
简单题,考虑将集合抽象成 \(01\) 序列,这个时候发现原问题被转化成了如下问题:
- 区间推平 \(1\)
- 区间推平 \(0\)
- 区间取反
然后查询就是查询序列中第一个 \(0\)。
此时你会发现 \(\text{ODT}\) 还是可能会被卡掉(不过据说没有卡)。
因为我们的复杂度大头在于查询的时候是从头开始向后扫,所以只要我们前部分的 \(1\) 尽量在一个块内就可以了,此时考虑扫的过程中合并 \(1\) 的散块,这样就能保证此时复杂度的正确。
考虑如果不合并,则可能出现进行构造的数据使得前部分全是 \(1\) 的散块,则此时很容易 \(\text{TLE}\) 掉。
所以如果我们让前部分的 \(1\) 合并,则此时查询的时候复杂度在 \(O(1)\) 到 \(O(n)\) 徘徊,但是此时会出现问题,如果出题人想要卡掉合并这一个方法,则会出现修改于查询的比例不对称,如果想尽可能减小此时的比例,则必然 \(0\) 会出现的很早,所以易证此时复杂度是正确的。
CF343D Water Tree
考虑这本质上就是一个区间推平 \(01\) + 单点查询,所以此时我们显然可以使用 \(\text{ODT}\)
那么关于 \(\text{ODT}\) 的单点查询,直接 lower_bound
就好,不要像我一样乱搞一气(虽然也过了/dk)。
时间复杂度 \(O(n \log n)\)
请问您今天要来点 ODT 吗的更多相关文章
- 安卓,支付宝app登录时,提示 服务器安全证书已过期或不可信任,请问怎么解决
安卓,支付宝app登录时,提示 服务器安全证书已过期或不可信任,请问怎么解决 请把手机时间调成当前时间.
- 请问-bash-4.1$ 出现故障的原理及解决办法?
请问如下登录环境故障的原理及解决办法? [root@ ~]# su - luoahong -bash-4.1$ -bash-4.1$ 解答: [luoahong@ ~]$ rm -rf /home/l ...
- [部署]MVC4.0+EF5.0+ODT+ORACLE相关注意事项
摘要 项目开发工具:VS2012旗舰版(.NetFrameWork4.5.1),WIN7 64bit,Oracle 11g 服务器环境:Windows Server2008 R2 64bit,.Net ...
- 一个类有两个方法,其中一个是同步的,另一个是非同步的; 现在又两个线程A和B,请问:当线程A访问此类的同步方法时,线程B是否能访问此类的非同步方法?
一个类有两个方法,其中一个是同步的,另一个是非同步的:现在又两个线程A和B,请问:当线程A访问此类的同步方法时,线程B是否能访问此类的非同步方法? 答案:可以 验证 package com.my.te ...
- 请问下./在Linux下是什么意思
请问下./在Linux下是什么意思 http://zhidao.baidu.com/link?url=1f-80KN7cdi-7XECpwXLUn6Ps4reMBL2zB6eiDk7JliwDgW6k ...
- 请问用Inno_Setup打包文件夹时怎么排除其中一个文件?
请问用Inno_Setup打包文件夹时怎么排除其中一个文件? 该文件夹下有几十个文件,多个文件夹,我要一个个加进去该累死,也容易出问题.不知道能不能实现我要的目的. http://www.jrsoft ...
- FineReader Mac如何设置参数让导出为DOCX/RTF/ODT格式
Mac版ABBYY FineReader OCR文字识别软件识别文档之后,可以将已识别的文本保存到文件中,还可以通过电子邮件发送输出格式受FineReader支持的已识别文本,了解了ABBYY Fin ...
- 阿里云ECS服务器被DDoS无解,请问我该何去何从?
阿里云ECS服务器被DDoS无解,请问我该何去何从?
- Unity问答——请问一下动画状态机怎么判断动画是否播完了?
这篇博客源自我在泰课在线的回答.链接:http://www.taikr.com/group/1/thread/233 问:请问一下动画状态机怎么判断动画是否播完了? 答: 1. 脚本参考 Animat ...
- 我家用的网络IP地址给定,MAC绑定,我买了个无线路由器,请问怎么设定能让我的电脑和手机都能上网
我家用的网络IP地址给定,MAC绑定,我买了个无线路由器,请问怎么设定能让我的电脑和手机都能上网 房东给的IP地址是:192.168.1.5 255.255.255.0 192.168.1.1 2 ...
随机推荐
- 如何在Avalonia11中设置自定义字体
如何在Avalonia11中设置自定义字体 由于avalonia默认的中文字体显示的效果不太理想,我们需要下载一些自定义的字体,来优化UI的显示效果.avalonia的官方文档地址. 对我在项目中运用 ...
- 零基础入门——从零开始学习PHP反序列化笔记(二)
魔术方法 魔术方法介绍 __construct() 触发时机:实例化对象之前 构造函数,在实例化一个对象的时候,首先会去自动执行的一个方法; <?php class User { public ...
- Prism报错
Rules.Default..WithoutFastExpressionCompiler()报错 说没有找到容器 1.查看Prism.Wpf源码 获取DryIoc容器规则 2.证明项目中出现了另外一个 ...
- AgileConfig-1.7.0 发布,支持 SSO 🎉🎉🎉
AgileConfig 已经好久好久没有更新过比较大的功能了.一是 AgileConfig 本身的定位就是比较轻量,不想集成太多的功能.二是比较忙(懒).但是本次升级给大家带来了一个比较有用的功能 S ...
- 深入理解Linux内核——内存管理(3)
提要:本系列文章主要参考MIT 6.828课程以及两本书籍<深入理解Linux内核> <深入Linux内核架构>对Linux内核内容进行总结. 内存管理的实现覆盖了多个领域: ...
- 商品详情接口设计:使用API调用获取淘宝商品数据的完整方案
在如今的电商时代,获取商品的详细信息是实现商业化应用的基础.本文将详细介绍如何通过API调用来获取淘宝商品数据,并提供一个完整的商品详情接口设计方案,包括代码示例.开发人员可以根据此方案快速实现商 ...
- 应用程序通过 Envoy 代理和 Jaeger 进行分布式追踪 —— Ingress Controller + Http服务 + Grpc服务(三)
1.概述 在<应用程序通过 Envoy 代理和 Jaeger 进行分布式追踪(一)>这篇博文中,我们详细介绍了单个应用程序通过 Envoy 和 Jaeger 实现链路追踪的过程.通过这个示 ...
- Markdown初识
1.标题 一级标题 ctrl+1......六级标题 ctrl+6 2.字体 加粗 ctrl+B 斜体 ctrl+I 下划线 ctrl+ U 3.引用 大于号加任意键 4.分割线 "---& ...
- GDB苹果网页一键打包工具(IOS,IPA,苹果应用网页打包,WINDOWS平台)
工具简介 GDB苹果网页一键打包工具(IOS,IPA,苹果应用网页打包,Windows平台)可以把本地HTML项目或者网站打包为一个苹果应用IPA文件,无需编写任何代码,支持在苹果设备上安装运行.作为 ...
- Windows上Dart安装
过程 *1 去github上下载一个release包或者直接将flutter通过git clone下来 *2 将下载下来的flutter/bin添加到path中 *3 此时运行flutter或者flu ...