【bzoj3211】花神游历各国

2014年3月17日2,7230

Description

 

Input

 

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;

  所以势能分析即可,

  最坏情况是O(log * 10^9 m)

  1. #include<cstring>
  2. #include<cmath>
  3. #include<algorithm>
  4. #include<iostream>
  5. #include<cstdio>
  6.  
  7. #define N 100007
  8. #define ll long long
  9. using namespace std;
  10. inline int read()
  11. {
  12. int x=,f=;char ch=getchar();
  13. while(ch>''||ch<''){if (ch=='-') f=-;ch=getchar();}
  14. while(ch<=''&&ch>=''){x=(x<<)+(x<<)+ch-'';ch=getchar();}
  15. return x*f;
  16. }
  17. int n,m;
  18. ll a[N];
  19. struct data
  20. {
  21. int l,r;
  22. ll sum;
  23. bool flag;
  24. }tr[N<<];
  25.  
  26. inline void update(int p)
  27. {
  28. tr[p].sum=tr[p<<].sum+tr[p<<|].sum;
  29. tr[p].flag=tr[p<<].flag&tr[p<<|].flag;
  30. }
  31. void build(int p,int l,int r)
  32. {
  33. tr[p].l=l;tr[p].r=r;
  34. if(l==r)
  35. {
  36. tr[p].sum=a[l];
  37. if(a[l]==||a[l]==)tr[p].flag=;
  38. return;
  39. }
  40. int mid=(l+r)>>;
  41. build(p<<,l,mid),build(p<<|,mid+,r);
  42. update(p);
  43. }
  44. void modify(int p,int x,int y)
  45. {
  46. if(tr[p].flag)return;
  47. int l=tr[p].l,r=tr[p].r;
  48. if(l==r)
  49. {
  50. tr[p].sum=(ll)sqrt(tr[p].sum);
  51. if(tr[p].sum==||tr[p].sum==)tr[p].flag=;
  52. return;
  53. }
  54. int mid=(l+r)>>;
  55. if(mid>=y) modify(p<<,x,y);
  56. else if(mid<x) modify(p<<|,x,y);
  57. else modify(p<<,x,mid),modify(p<<|,mid+,y);
  58. update(p);
  59. }
  60. ll query(int p,int x,int y)
  61. {
  62. int l=tr[p].l,r=tr[p].r;
  63. if(l==x&&r==y)return tr[p].sum;
  64. int mid=(l+r)>>;
  65. if(mid>=y)return query(p<<,x,y);
  66. else if(mid<x)return query(p<<|,x,y);
  67. else return query(p<<,x,mid)+query(p<<|,mid+,y);
  68. }
  69. int main()
  70. {
  71. n=read();
  72. for(int i=;i<=n;i++)
  73. a[i]=read();
  74. build(,,n);
  75. m=read();
  76. for(int i=;i<=m;i++)
  77. {
  78. int k=read(),x=read(),y=read();
  79. if(x>y)swap(x,y);
  80. if(k== )modify(,x,y);
  81. else printf("%lld\n",query(,x,y));
  82. }
  83. }

bzoj3211 花神游历各国 线段树,势能分析的更多相关文章

  1. bzoj3211: 花神游历各国(线段树) 同codevs2492

    3211: 花神游历各国 Time Limit: 5 Sec  Memory Limit: 128 MBSubmit: 3628  Solved: 1326[Submit][Status][Discu ...

  2. bzoj3211花神游历各国 线段树

    3211: 花神游历各国 Time Limit: 5 Sec  Memory Limit: 128 MBSubmit: 4252  Solved: 1547[Submit][Status][Discu ...

  3. BZOJ3211花神游历各国-线段树&树状数组-(HDU4027同类型)

    (有任何问题欢迎留言或私聊 && 欢迎交流讨论哦 题意:BZOJ HDU  原题目描述在最下面.  两种操作,1:把区间的数字开方一次,2:区间求和. 思路: 线段树:  显然不能暴力 ...

  4. BZOJ3211:花神游历各国(线段树)

    Description Input Output 每次x=1时,每行一个整数,表示这次旅行的开心度 Sample Input 4 1 100 5 5 5 1 1 2 2 1 2 1 1 2 2 2 3 ...

  5. BZOJ 3038: 上帝造题的七分钟2 / BZOJ 3211: 花神游历各国 (线段树区间开平方)

    题意 给出一些数,有两种操作.(1)将区间内每一个数开方(2)查询每一段区间的和 分析 普通的线段树保留修改+开方优化.可以知道当一个数为0或1时,无论开方几次,答案仍然相同.所以设置flag=1变表 ...

  6. BZOJ 3211: 花神游历各国( 线段树 )

    线段树...区间开方...明显是要处理到叶节点的 之前在CF做过道区间取模...差不多, 只有开方, 那么每个数开方次数也是有限的(0,1时就会停止), 最大的数10^9开方10+次也就不会动了.那么 ...

  7. GSS4 - Can you answer these queries IV || luogu4145上帝造题的七分钟2 / 花神游历各国 (线段树)

    GSS4 - Can you answer these queries IV || luogu4145上帝造题的七分钟2 / 花神游历各国 GSS4 - Can you answer these qu ...

  8. luogu 4145 花神游历各国 线段树/树状数组+并查集

    此题一看便是RMQ问题,但是由于开平方的特殊操作,tag操作失效 此时发现特性:sqrt最多执行6此便使值到达1/0,此时可以剪枝不进行该操作,利用并查集到达特性找根,根代表还可以进行操作的点,再利用 ...

  9. BZOJ3211 花神游历各国 【树状数组 + 并查集】

    题目 输入格式 输出格式 每次x=1时,每行一个整数,表示这次旅行的开心度 输入样例 4 1 100 5 5 5 1 1 2 2 1 2 1 1 2 2 2 3 1 1 4 输出样例 101 11 1 ...

随机推荐

  1. siege4安装和使用介绍

    使用文档参考地址:https://www.joedog.org/siege-manual/ siege4地址:http://download.joedog.org/siege/ cd /usr/loc ...

  2. Django之CSRF问题

    1.csrf全称:cross site request forgery(跨站请求伪造),举例来讲,一个安全的网站A,一个恶意网站B,当你在A网站进行了登录后,这时候浏览器会保存你的cookie和ses ...

  3. vertx从入门到精通

    1.Vert.x安装指南 http://blog.csdn.net/sdyy321/article/details/38926005 http://blog.csdn.net/chszs/articl ...

  4. 实用IMX6开发板来袭, 方便开发板方便你

    这是迅为电子推出的一款IMX6Q开发板是Freescale Cortex-a9四核处理器,采用底板加核心板形式,稳定耐用,拆卸非常的方便,同一底板兼容四种核心板,分别为四核商业级,四核工业级,双核商业 ...

  5. mysql利用binlog恢复数据详细例子

    模拟数据恢复的案例 有些时候脑瓜就会短路,难免会出错 场景:在生产环境中,我们搭建了mysql主从,备份操作都是在从备份数据库上 前提:有最近一天或者最近的全备 或者最近一天相关数据库的备份 最重要的 ...

  6. CS 分解

    将学习到什么 CS 分解是分划的酉矩阵在分划的酉等价之下的标准型. 它的证明涉及奇异值分解.QR 分解以及一个简单习题.   一个直观的习题 设 \(\Gamma, L \in M_p\). 假设 \ ...

  7. CPP-基础:内部函数应该在当前源文件中说明和定义

    static函数与普通函数作用域不同,仅在本文件.只在当前源文件中使用的函数应该说明为内部函数(static),内部函数应该在当前源文件中说明和定义.对于可在当前源文件以外使用的函数,应该在一个头文件 ...

  8. false - (失败的)什么都不做

    总览 (SYNOPSIS) false [忽略命令行参数] false OPTION 描述 (DESCRIPTION) 程序 结束 时, 产生 表示 失败 的 状态码. 下列的 选项 没有 简写 形式 ...

  9. C# 文件操作的工具类

    using System.IO; namespace 文件操作类 { public class FileHelper { /// <summary> /// 判断文件是否存在 /// &l ...

  10. Js自学学习-笔记6-8

    <!-- 第6-7课笔记 --> <!-- for循环 for(条件1:判断:变化)其实就是if嵌套 while do for循环简化版 可以用do while swith case ...