题意:

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【线段树-神题】的更多相关文章

  1. Bzoj 4408: [Fjoi 2016]神秘数 可持久化线段树,神题

    4408: [Fjoi 2016]神秘数 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 177  Solved: 128[Submit][Status ...

  2. hdu-1540线段树刷题

    title: hdu-1540线段树刷题 date: 2018-10-18 19:55:21 tags: acm 刷题 categories: ACM-线段树 概述 哇,,,这道线段树的题可以说是到目 ...

  3. [AHOI 2009] 维护序列(线段树模板题)

    1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec  Memory Limit: 64 MB Description 老师交给小可可一个维护数列的任务,现在小 ...

  4. POJ 3468 线段树裸题

    这些天一直在看线段树,因为临近期末,所以看得断断续续,弄得有些知识点没能理解得很透切,但我也知道不能钻牛角尖,所以配合着刷题来加深理解. 然后,这是线段树裸题,而且是最简单的区间增加与查询,我参考了A ...

  5. hdu-5023线段树刷题

    title: hdu-5023线段树刷题 date: 2018-10-18 13:32:13 tags: acm 刷题 categories: ACM-线段树 概述 这道题和上次做的那道染色问题一样, ...

  6. poj-2777线段树刷题

    title: poj-2777线段树刷题 date: 2018-10-16 20:01:07 tags: acm 刷题 categories: ACM-线段树 概述 这道题是一道线段树的染色问题,,, ...

  7. zoj-1610线段树刷题

    title: zoj-1610线段树刷题 date: 2018-10-16 16:49:47 tags: acm 刷题 categories: ACM-线段树 概述 这道题是一道简单的线段树区间染色问 ...

  8. 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个操作,但是顺序是乱的,现在每输入一个操作要求你输出当前的栈顶, 注意,已有操作要按它们的 ...

  9. hdu 1754 I Hate It 线段树基础题

    Problem Description 很多学校流行一种比较的习惯.老师们很喜欢询问,从某某到某某当中,分数最高的是多少. 这让很多学生很反感. 不管你喜不喜欢,现在需要你做的是,就是按照老师的要求, ...

随机推荐

  1. webpack4.0入门以及使用

    1. 安装webpack 先新建一个文件夹(demos),然后 npm init -y 新建一个package.json然后在当前目录执行webpack命令 webpack 模块未发现或者未找到src ...

  2. centos或者ubuntu设置ssh免密码登陆

    1. 输入  # ssh-keygen -t rsa -P ""  然后一路回车 2.输入  # cat ~/.ssh/id_rsa.pub >> ~/.ssh/aut ...

  3. [UnityShader3]溶解与重现效果

    參考链接:http://www.cnblogs.com/Esfog/p/DissolveShader.html 效果图: 从颜色变化来说,有三种,一种是纹理颜色.一种是纹理与黑边的混合颜色,一种是透明 ...

  4. 【转载】FAT12格式的引导程序(2)

     1.用WinImage来写入到引导区的详细步骤: 启动WinImage后,打开“文件”菜单,单击菜单中的“打开”命令. 选择之前保存的磁盘镜像文件“boot.img”或者“boot.ima”. 打开 ...

  5. uboot 对 FAT 分区的解析

    uboot 对 FAT 分区的解析 改写 UBOOT 从 U 盘读入固件,然后刷机.发现有的 U 盘无法正确读到分区,跟踪了一下发现自己写的代码有漏洞,只尝试解析分区表里的第一个分区.跟踪的过程中重温 ...

  6. linux 文件记录锁详解

    一: linux记录锁更恰当的称呼应该是范围锁,它是对文件某个范围的锁定. 关于记录锁的功能就是fcntl提供的第五个功能,具体使用如下: int fcntl(int fd, int cmd, str ...

  7. shell学习五十六天----延迟进程调度

    延迟进程调度 前言:大部分时候,我们都希望进程快点開始,开点结束,别卡.而shell的运行,也是在前一个命令后,立即接着运行下一个命令.命令完毕的速度是与资源的限制有关,且不在shell的权限下. 在 ...

  8. cocos2d-x(vs2012)环境搭建(第一篇)[版本号:cocos2d-x-3.1.1]

    1.下载资源 下载cocos2d-x包V3.1.1,下载戳这里: http://www.cocos2d-x.org/download vs2012下载戳这里: http://www.xiazaiba. ...

  9. huawei校招测试题

    三道题两小时. 第一题,圈住所有点的长方形,很简单略过. 第二题:奇偶排序. 奇偶排序 描述: 输入若干(不超过1000个)非负整数数字,请先取出为奇数的数字按从大到小排序,再取出偶数从小到大进行排序 ...

  10. STM32低功耗模式与烟雾报警器触发信号电路设计

    1.STM32的3种低功耗模式 STM32有3种低功耗模式,分别是睡眠模式.停机模式和待机模式. 2.STM32在不同模式下的电流消耗 a.工作模式  消耗电流在27mA至36mA之间. b.睡眠模式 ...