2016多校8th 1008【线段树-神题】
题意:
T
N M
N个数
M个操作
一个数组A,
有3个操作
1 l r x,a[l]…a[r]都+x
2 l r,a[i]=sqrt(a[i]),l<=i<=r
3 l r,求和,a[i], l<=i<=r
操作3的时候输出
n,m(1<=n,m<=100000).
1<=A[i],x<=100000.
思路:
前言(读者可略过,看了请小喷qaq,欢迎指出错误):
我突然开始困惑复杂度的问题:
如果区间内所有的数都不相等,那么每次sqrt一下的时间复杂度多少?O(nlogn)?不是,翻书可知建树的时间复杂度是o(n)(因为节点数是2n),所以这里如果对区间所有数都sqrt一次也是o(n)啊。
那什么是O(logn),对于单值改变和区间查询是O(logn),因为复杂度只是树的深度。
正言:
以前写过一题hdu4027,也是线段树维护开方的,但是只有开方,我们都知道,在一定范围内开方没几次就是1了,这里不一样,这里还有加操作。。。这就不知道了。。。呜呜呜。。。
然后看了很多博客说是,某些区间内开几次就会变成1,然后标记一下区间是不是全部相等。。。
说实话,还是没怎么懂。。。
问题就是:
如果我就是数据是在一个大区间sqrt一下,然后再在这个大区间加一下,一直m次…那不是也就是时间复杂度爆炸么?
然后hdu上还加了一个毒数据(膜拜各种会玩dalao)。。
2 3 2 3 2 3 …
8 9 8 9 8 9 … (+6)
2 3 2 3 2 3 … (sqrt)
8 9 8 9 8 9 … (+6)
2 3 2 3 2 3 … (sqrt)
这个数据说明了我很可能办到这样不相等的情况,然后有了一个优化解法,原文:“可以发现区间内的极差>1的时候是不能办到这样的,只有整个区间内的极差<=1的时候,才能起到这种效果。所以我们就在线段树上再增加一些信息。就是最大值和最小值,最大值的个数,最小值的个数。这样的话,如果区间内的极差==1的时候,我们也能直接对整段进行操作。就能处理前面的这种样例了。”(感觉有点想特判…勿喷qaq);
其实都到这份上,这道题目再讲下去对于自己的水平也没有意义了。。。
这道题目的好:
1.对于线段树区间元素的表示,以及完美地利用线段树的性质达到一种处理,都是非常棒的。
2.这道题目的lazy操作也是很赞啊。query求sum以及更新操作的加都是一般可以解决,更新加操作需要一个lazy,然后标记某段区间是否相等,也要用到一个lazy。。对于lazy操作的写法,没写过很多很多题也是写不出来的。这题要想靠自己A掉,还要时间啊。先把基础搞好吧。
暂时放弃。
2016多校8th 1008【线段树-神题】的更多相关文章
- Bzoj 4408: [Fjoi 2016]神秘数 可持久化线段树,神题
4408: [Fjoi 2016]神秘数 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 177 Solved: 128[Submit][Status ...
- hdu-1540线段树刷题
title: hdu-1540线段树刷题 date: 2018-10-18 19:55:21 tags: acm 刷题 categories: ACM-线段树 概述 哇,,,这道线段树的题可以说是到目 ...
- [AHOI 2009] 维护序列(线段树模板题)
1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec Memory Limit: 64 MB Description 老师交给小可可一个维护数列的任务,现在小 ...
- POJ 3468 线段树裸题
这些天一直在看线段树,因为临近期末,所以看得断断续续,弄得有些知识点没能理解得很透切,但我也知道不能钻牛角尖,所以配合着刷题来加深理解. 然后,这是线段树裸题,而且是最简单的区间增加与查询,我参考了A ...
- hdu-5023线段树刷题
title: hdu-5023线段树刷题 date: 2018-10-18 13:32:13 tags: acm 刷题 categories: ACM-线段树 概述 这道题和上次做的那道染色问题一样, ...
- poj-2777线段树刷题
title: poj-2777线段树刷题 date: 2018-10-16 20:01:07 tags: acm 刷题 categories: ACM-线段树 概述 这道题是一道线段树的染色问题,,, ...
- zoj-1610线段树刷题
title: zoj-1610线段树刷题 date: 2018-10-16 16:49:47 tags: acm 刷题 categories: ACM-线段树 概述 这道题是一道简单的线段树区间染色问 ...
- Codeforces Round #393 (Div. 2) (8VC Venture Cup 2017 - Final Round Div. 2 Edition) E - Nikita and stack 线段树好题
http://codeforces.com/contest/760/problem/E 题目大意:现在对栈有m个操作,但是顺序是乱的,现在每输入一个操作要求你输出当前的栈顶, 注意,已有操作要按它们的 ...
- hdu 1754 I Hate It 线段树基础题
Problem Description 很多学校流行一种比较的习惯.老师们很喜欢询问,从某某到某某当中,分数最高的是多少. 这让很多学生很反感. 不管你喜不喜欢,现在需要你做的是,就是按照老师的要求, ...
随机推荐
- MFC 小知识总结三
1 载入资源位图 1 获取程序实例 HINSTANCE m_hInst; m_hInst=AfxGetInstanceHandle(); //获取程 ...
- Version和Build的差别
[1]概念 iOS的版本号号.一个叫做Version,一个叫做Build,这两个值都能够在Xcode 中选中target,点击"Summary"后看到. Version在plist ...
- jobject和jclass
jclass和jobject的迷惑第一次使用JNI,实例引用(jobject)和类引用(jclass)让人觉得很困惑.实例引用与一个数组和java.lang.Object类或它的子类的实例对应.类引用 ...
- C#语言 循环语句
//Console.Write("请输入关卡数:"); //int a = int.Parse(Console.ReadLine()); //int s = 0; //if (a ...
- 【万里征程——Windows App开发】控件大集合1
加入控件的方式有多种.大家更喜欢哪一种呢? 1)使用诸如 Blend for Visual Studio 或 Microsoft Visual Studio XAML 设计器的设计工具. 2)在 Vi ...
- 对FreeMarker技术的思考
依照静态非静态来划分网页分为两种:静态网页和非静态网页,究其优缺点而言,静态网页在用户訪问的时候响应快,可是因为里面的数据是写死的.所以致命的缺陷就是数据不能动态显示.非静态页面(如jsp)数据能够动 ...
- Liunx之Lamp搭建笔记
1:LAMP源代码搭建用户关系 a. apache服务以daemon用户的处理请求.以root身份作为主进程. b. php源代码安装,会在httpd.conf文件里自己主动增加调用模块.可是在该文 ...
- Android Baseline小tip
转载请注明出处:http://blog.csdn.net/bbld_/article/details/40709353 Baseline Alignment
- hadoop mapred和mapreduce包
mapred包是老的1.0的map reduce api mapreduce包是新的2.0的map reduce api
- OOalv 实现带出栏位描述
.类定义 CLASS lcl_event_handler DEFINITION. PUBLIC SECTION. METHODS: handle_data_changed_finished FOR E ...