【Codeforces 1109C 】Sasha and a Patient Friend
Codeforces 1109 C
题意:现在有个碗,每时每刻其中的水量都会加一个整数(可以为负)。
给\(n\)个询问,询问有\(3\)种类型:
- \(1\ t\ s\):将从第\(t\)秒开始水量增加的速度改为\(s\)。
- \(2\ t\):删除第\(t\)秒对水量增加速度的改变。
- \(3\ l\ r\ v\):考虑从第\(l\)秒到第\(r\)秒对水量增加速度的改变,并假设初始时水量为\(v\),问什么时候水量降至\(0\)。
思路:一看就是道数据结构题。
前两个操作其实都是改变一个时间段的水量增加速度,即区间修改,用线段树维护每一秒的水量增加速度,每个区间和就是一段时间中水量的变化情况。
由于时间段十分长,离散化用到的(即改变过水量增加速度的)时间。然后就要注意了区间不是等长的,求和时要带上一个系数表示这个区间的长度。
然后考虑第三个操作。
这里有两种处理方法,个人写的第一种会TLE,P.S.我写的版本也过了。其实是我线段树的问题:
在我的线段树的下推操作中,我只是将当前的节点的值根据该区间赋的值来更改,并且把标记下推到了下一层节点,但是跑到下一层节点后还得再下推,即使到了最后一层也是如此。所以,最后一层的下推操作就是浪费时间,几乎浪费了两倍,那么就将下推操作改成把两个儿子节点的值都更改了即可。
而别人(ko_osaga)就过了,可能是我自带大常数吧。
- 第一种是二分第一次降至\(0\)的位置\(l\leq i\leq r\),判断\([l,i)\)区间中最小前缀和\(+v\)是否小于等于\(0\),如果如此则说明到\(i\)为止水量降为\(0\)过了,则把二分的右边界缩小,否则将二分的左边界扩大。
- 第二种是在线段树上二分。假设现在在线段树的\([a,b)\)区间,其中点为\(mid\),如果\([a,mid)\)区间中最小前缀和\(+\)当前所查的\(v\)小于等于\(0\),则说明在\([a,mid)\)中水量已经降为\(0\)过了。否则必须在\([mid,b)\)中才使水量降为\(0\),则需要使\([mid,b)\)中的最小前缀和加上\([a,mid)\)的和\(+v\)小于等于\(0\),则\([mid,b)\)所查的\(v\)为\(v+[a,mid)\)的和。
然后就是要考虑怎么求一个区间的最小前缀和了。
在线段树上多记录一个数据\(mn\),表示这个节点表示的区间中的最小前缀和。
在对整个节点所表示的区间都刷上一个值时,该节点的\(mn\)只可能是两种情况:\(0\)或该节点的和。因为如果刷上的那个值\(<0\),那么该节点所表示的区间前缀和递减,则肯定取该节点的和为\(mn\),否则区间前缀和递增,必须取\(0\)为\(mn\)。
在修改结束的上推操作中,该节点的\(mn\)应该取左节点的\(mn\)和右节点的\(mn+\)左节点的和的最小值,因为该节点的最小前缀和可能跨左节点的区间也可能不跨。
每个操作的具体处理:
用一个\(set\)保存所有的更改水量增加速度的事件。然后找到当前事件后一个是什么。把中间一段都修改成当前要修改到的速度即可。
找到当前事件前一个是什么。把当前事件到其后一个的中间一段修改成前一个所修改到的速度即可。
按照上面所说二分即可。
还有一种方法是用一个\(treap\)来维护所有的更改操作,按照发生的时间排序(Um_nik)。
既然\(treap\)的每个节点代表了一个更改操作,那么这个节点所挂的子树就代表了一个区间(一堆操作中最早的到最晚的)。
在\(treap\)的每个节点中需要维护以下信息:
- 这个节点所存的更改操作的时间、将要改到的速度
- 这个节点所挂子树所代表的区间的开始时间和结束时间,以及最后一个时间点的水量增加速度
- 从这个子树表示的区间的开始到结束每个时间点的水量增加速度之和
- 这个子树表示的区间的最小前缀和
然后\(split\)和\(merge\)两个操作都和正常的\(treap\)差不多,但是需要增加一个\(pushup\)操作来更新和与最小前缀和:
该子树的和就是左子树的和\(+\)右子树的和\(+\)左右子树都没有计算到的部分
左右子树都没有计算到的部分是从左子树的最后一个操作到当前节点的操作再到右子树的第一个操作的区间。
如果没有左右子树,则需要特判一下。
每个询问的处理:
插入:将\(treap\)分成小于\(t\)和大于\(t\)两部分,然后把新加入的节点放在中间,\(merge\)回去。
删除:将\(treap\)分成小于\(t\)、等于\(t\)、大于\(t\)三部分,然后把中间那个节点拿去,\(merge\)回去。
查询:将\(treap\)分成小于\(l\)、\(l \leq x \leq r\)、大于\(r\)三部分,然后在中间的那个部分中二分:
如果当前节点的左子树的最小前缀和\(+v\)小于等于\(0\),则在左子树里找;
如果当前节点的左右子树都没计算到的部分加上左子树的和\(+v\)小于等于\(0\),则算一下等于\(0\)时在哪,直接输出。
否则就肯定在右子树里了。现在的\(v\)需要加上左子树和加左右子树都没计算到的部分。
然后这种方法常数稍微比线段树小一点?
【Codeforces 1109C 】Sasha and a Patient Friend的更多相关文章
- 【codeforces 719E】Sasha and Array
[题目链接]:http://codeforces.com/contest/719/problem/E [题意] 给你一个数列,有两种操作1 l r x 给[l,r]区间上的数加上x, 2 l r 询问 ...
- 【codeforces 1109B】Sasha and One More Name
[链接] 我是链接,点我呀:) [题意] 题意 [题解] 如果这个回文串的左半部分,字母全是一样的. 那么显然不可能再分出来了,因为不管怎么分怎么排列,最后肯定都只能和原串一样. 所以无解 其他情况下 ...
- 【codeforces 415D】Mashmokh and ACM(普通dp)
[codeforces 415D]Mashmokh and ACM 题意:美丽数列定义:对于数列中的每一个i都满足:arr[i+1]%arr[i]==0 输入n,k(1<=n,k<=200 ...
- 【codeforces 761B】Dasha and friends
time limit per test2 seconds memory limit per test256 megabytes inputstandard input outputstandard o ...
- 【codeforces 707E】Garlands
[题目链接]:http://codeforces.com/contest/707/problem/E [题意] 给你一个n*m的方阵; 里面有k个联通块; 这k个联通块,每个连通块里面都是灯; 给你q ...
- 【codeforces 707C】Pythagorean Triples
[题目链接]:http://codeforces.com/contest/707/problem/C [题意] 给你一个数字n; 问你这个数字是不是某个三角形的一条边; 如果是让你输出另外两条边的大小 ...
- 【codeforces 709D】Recover the String
[题目链接]:http://codeforces.com/problemset/problem/709/D [题意] 给你一个序列; 给出01子列和10子列和00子列以及11子列的个数; 然后让你输出 ...
- 【codeforces 709B】Checkpoints
[题目链接]:http://codeforces.com/contest/709/problem/B [题意] 让你从起点开始走过n-1个点(至少n-1个) 问你最少走多远; [题解] 肯定不多走啊; ...
- 【codeforces 709C】Letters Cyclic Shift
[题目链接]:http://codeforces.com/contest/709/problem/C [题意] 让你改变一个字符串的子集(连续的一段); ->这一段的每个字符的字母都变成之前的一 ...
随机推荐
- javascript如何处理很多数据,类似分页切换
需求:一个用户列表数据,如果对应列表数据大于10个,就每10个保存到二维数组,后面不足10个的依然放在二维数组尾部 用处:模拟分页,或者局部刷新 在线DEMO:戳这里 var obj=[ { &quo ...
- javasript中var、let和const区别
let和const都是es5,es6新版本的js语言规范出来的定义,在这以前定义一个变量只能用var.let和const都是为了弥补var的一些缺陷而新设计出来的. 简单来说是: let是修复了var ...
- python爬虫简单代码爬取郭德纲单口相声
搜索老郭的单口相声,打开检查模式,刷新 没有什么有价值的东东, 不过....清掉内容, 点击一个相声,再看看有些什么 是不是发现了些什么 我们来点击这个看看, 首先看一下headers, 这个url是 ...
- js之选项卡(tag标签)
目标效果:点击不同按钮显示不同内容 代码如下 <!DOCTYPE html> <html lang="en"> <head> <meta ...
- 通过了解JS的clientX、pageX、screenX等方法来获取鼠标位置相对屏幕,相对浏览器窗口,相对文档的坐标详解
在一些DOM操作中我们经常会跟元素的位置打交道,鼠标交互式一个经常用到的方面,令人失望的是不同的浏览器下会有不同的结果甚至是有的浏览器下没结果,这篇文章就上鼠标点击位置坐标获取做一些简单的总结,没特殊 ...
- 共用的h5回调页面
产生背景: APP里的公用页面,像帮助中心页.授权认证结果页.各种协议页面,都需要做成H5页面,方便安卓和ios去调用. 交互情况描述: 要是有动态值,就需要定义在自己H5链接的后面,让他们传值,自己 ...
- element-ui select组件中复选时以字符串形式显示
我使用的element-ui的版本是1.4.13. 如上图所示,使用el-select组件,要实现可搜索.可复选.可创建条目时,展示样式是如上图所示,输入框的高度会撑开,影响页面布局,按照产品的需求, ...
- 【读书笔记】iOS-Nib的一些知识
Apple在Xcode4.2中推出用于iOS应用故事版概念. 标识:Identity(标识)检查器最常用于为用户界面元素或者控制器分配一个自定义类. 属性:Attributes(属性)检查器在微调用户 ...
- 【读书笔记】iOS-OCUnit-单元测试
一,新建立一个hello工程--->在左侧会看到helloTests---->helloTests.m.如下图所示. 二,打开查看会看到如下代码. #import <UIKit/UI ...
- IOS7如何获取设备唯一标识
WWDC 2013已经闭幕,IOS7 Beta随即发布,界面之难看无以言表...,简直就是山寨Android. 更让IOS程序猿悲催的是,设备唯一标识的MAC Address在IOS7中也失效了. I ...