这是一道关于线段树的区间开根号的裸题,没什么好讲的。

  值得注意的是,因为有区间开根号的性质,所以我们每一次更改操作只能把更改区间所覆盖的所有元素全部查找,当然你直接找效率明显爆炸。。。

  能够注意到,指数级别的操作一次更改的数字都很大,而题目的数字最大是10的9次,所以可以注意到的是当一个区间更新6遍以后就失去更新的意义了,因为当你更改次数超过6次所有非负整数数字就全部会化为1。所以可以在每一个节点上加一个类似于LAZY标记的东西,记录开根号次数,以便节约跟新时间。

  贴出题目&代码

Description

 线段树区间开根号与求和

Input

 第一行N代表有N个数
第二行有N个数,代表这N个值分别是多少
第三行有一个M
接下来M行,每行有X,L,R
当X为1代表求区间:(L,R)的和。
当X为2代表对区间:(L,R)开根号。

Output

每次x=1时,每行一个整数,表示区间和

Sample Input

4

1 100 5 5


5


1 1 2


2 1 2


1 1 2


2 2 3


1 1 4

Sample Output

101

11


11

HINT

对于100%的数据, n ≤ 100000,m≤200000 ,data[i]非负且小于10^9

  1. /**************************************************************
  2. Problem: 3211
  3. User: PencilWang
  4. Language: C++
  5. Result: Accepted
  6. Time:1996 ms
  7. Memory:9036 kb
  8. ****************************************************************/
  9.  
  10. #include<cstdio>
  11. #include<cmath>
  12. int n,m;
  13. struct shit{
  14. int L,R,t;
  15. long long num;
  16. }s[];
  17. int w[];
  18. void push_up(int p)
  19. {
  20. s[p].num=s[p<<].num+s[p<<|].num;
  21. return ;
  22. }
  23. void build(int p,int l,int r)
  24. {
  25. s[p].L=l;
  26. s[p].R=r;
  27. if(l==r)
  28. {
  29. s[p].num=w[l];
  30. return ;
  31. }
  32. int mid=(l+r)>>;
  33. build(p<<,l,mid);
  34. build(p<<|,mid+,r);
  35. push_up(p);
  36. return ;
  37. }
  38. void fuck(int p,int a,int b)
  39. {
  40. if(a<=s[p].L&&s[p].R<=b)
  41. {
  42. s[p].t++;
  43. if(s[p].L==s[p].R)
  44. {
  45. s[p].num=sqrt(s[p].num);
  46. return ;
  47. }
  48. }
  49. int mid=(s[p].L+s[p].R)>>;
  50. if(s[p<<].t<&&a<=mid)fuck(p<<,a,b);
  51. if(s[p<<|].t<&&b>mid)fuck(p<<|,a,b);
  52. push_up(p);
  53. return ;
  54. }
  55. long long Q(int p,int a,int b)
  56. {
  57. if(a<=s[p].L&&s[p].R<=b)
  58. {
  59. return s[p].num;
  60. }
  61. long long ans=;
  62. int mid=(s[p].L+s[p].R)>>;
  63. if(a<=mid) ans+=Q(p<<,a,b);
  64. if(b>mid)ans+=Q(p<<|,a,b);
  65. return ans;
  66. }
  67. int main()
  68. {
  69. int a,b,f;
  70. scanf("%d",&n);
  71. for(int i=;i<=n;i++)scanf("%d",w+i);
  72. scanf("%d",&m);
  73. build(,,n);
  74. while(m--)
  75. {
  76. scanf("%d%d%d",&f,&a,&b);
  77. if(f-)fuck(,a,b);
  78. else printf("%lld\n",Q(,a,b));
  79. }
  80. return ;
  81. }

3211

刷题向》关于线段树的区间开根号 BZOJ3211(NORMAL+)的更多相关文章

  1. hdu 4027 Can you answer these queries? 线段树区间开根号,区间求和

    Can you answer these queries? Time Limit: 1 Sec  Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/sho ...

  2. hdu 1556:Color the ball(线段树,区间更新,经典题)

    Color the ball Time Limit: 9000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)To ...

  3. hihoCoder #1078 : 线段树的区间修改(线段树区间更新板子题)

    #1078 : 线段树的区间修改 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 对于小Ho表现出的对线段树的理解,小Hi表示挺满意的,但是满意就够了么?于是小Hi将问题 ...

  4. 线段树离散化+区间更新——cf1179C好题

    绝对是很好的题 把问题转化成当第i个询问的答案是数值x时是否可行 要判断值x是否可行,只要再将问题转化成a数组里>=x的值数量是否严格大于b数组里的>=x的值 那么线段树叶子结点维护对于值 ...

  5. Codeforces Round #222 (Div. 1) D. Developing Game 线段树有效区间合并

    D. Developing Game   Pavel is going to make a game of his dream. However, he knows that he can't mak ...

  6. 2016年湖南省第十二届大学生计算机程序设计竞赛---Parenthesis(线段树求区间最值)

    原题链接 http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1809 Description Bobo has a balanced parenthes ...

  7. BZOJ 3110 ZJOI 2013 K大数查询 树套树(权值线段树套区间线段树)

    题目大意:有一些位置.这些位置上能够放若干个数字. 如今有两种操作. 1.在区间l到r上加入一个数字x 2.求出l到r上的第k大的数字是什么 思路:这样的题一看就是树套树,关键是怎么套,怎么写.(话说 ...

  8. HDU-6315 Naive Operations//2018 Multi-University Training Contest 2___1007 (线段树,区间除法)

    原题地址 Naive Operations Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 502768/502768 K (Java/ ...

  9. 线段树_区间加乘(洛谷P3373模板)

    题目描述 如题,已知一个数列,你需要进行下面三种操作: 1.将某区间每一个数乘上x 2.将某区间每一个数加上x 3.求出某区间每一个数的和 输入格式: 第一行包含三个整数N.M.P,分别表示该数列数字 ...

随机推荐

  1. 小晚wan的公众号

    转载请注明出处:http://blog.csdn.net/dongdong9223/article/details/70932630 本文出自[我是干勾鱼的博客] 小晚wan的公众号还是挺深刻的,有时 ...

  2. Windows10重启之后总是将默认浏览器设置为IE

    换了一台电脑之后,发现系统重启之后总是会把我的默认浏览器设置为IE,而自从用上了Chrome,我对他爱不释手. 上网找了不少文章,都建议使用系统自带的设置进行默认浏览器的设置,试了三四次,完全不起任何 ...

  3. Java设计模式百例 - 观察者模式

    观察者(Observer)模式定义了一种一对多的依赖关系,让多个观察者对象同时监听某一个主题对象,主体对象的状态变化会通知所有观察者对象.观察者模式又叫做发布-订阅(Publish/Subscribe ...

  4. 让ListView中的控件失去焦点:android:descendantFocusability="blocksDescendants"

    值得注意的是,ListView中的控件不能设置clickable="true",否则会无视父控件的blockDescendants. 可参考: https://segmentfau ...

  5. 完全卸载session 所需要的函数

    session_unset()  删除内存当中的session数据:必须放在session_destroy的前边.因为应用session_destory后session_id();就会消失. 删除se ...

  6. HDU - 6395:Sequence (分块+矩阵)

    题面太丑了,就不复制了. 题意:F1=A: F2=B: Fn=D*Fn-1+C*Fn-2+P/i:求Fn. 思路:根据P/i的值划分区间,每个区间矩阵求. 带常数的矩阵: #include<bi ...

  7. HohoCoder 1184 : 连通性二·边的双连通分量(+原理证明)

    1184 : 连通性二·边的双连通分量 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 在基本的网络搭建完成后,学校为了方便管理还需要对所有的服务器进行编组,网络所的老师 ...

  8. JMeter接口学习笔记2017

    协议学习地址:http://www.cnblogs.com/TankXiao/archive/2012/02/13/2342672.html 本篇学习笔记来自于慕课网上学习JMeter的学习笔记 学习 ...

  9. php跨域问题

    http://www.cnblogs.com/xiezn/p/5651093.html

  10. nginx config的多个config配置

    在我们的一台服务器上,一个nginx服务器下面可能跑着许多许多的项目; 那么就需要配置多个对应的配置 端口号 已经文件入库目录等等 那么项目多了以后,把这些项目都写到一个文件里 到后期难以查看与管理 ...