1. //Accepted 6628 KB 520 ms
  2. //I a b 把a到b区间的二进制位去反,转化成a到b区间的数全部加1
  3. //Q a 判断第a位的奇偶
  4. #include <cstdio>
  5. #include <cstring>
  6. #include <iostream>
  7. #include <queue>
  8. #include <cmath>
  9. #include <algorithm>
  10. using namespace std;
  11. /**
  12. * This is a documentation comment block
  13. * 如果有一天你坚持不下去了,就想想你为什么走到这儿!
  14. * @authr songt
  15. */
  16. ;
  17. struct node
  18. {
  19. int l,r;
  20. int add;
  21. int t;
  22. }f[imax_n*];
  23. string s;
  24. void build(int t,int l,int r)
  25. {
  26. f[t].l=l;
  27. f[t].r=r;
  28. f[t].add=;
  29. if (l==r)
  30. {
  31. f[t].t=s[l-]-';
  32. return ;
  33. }
  34. ;
  35. build(*t,l,mid);
  36. build(*t+,mid+,r);
  37. f[t].t=f[*t].t+f[*t+].t;
  38. }
  39. void update(int t,int l,int r,int c)
  40. {
  41. if (f[t].l==l && f[t].r==r)
  42. {
  43. f[t].add+=c;
  44. return ;
  45. }
  46. f[t].t+=(r-l+)*c;
  47. ;
  48. *t,l,r,c);
  49. else
  50. {
  51. *t+,l,r,c);
  52. else
  53. {
  54. update(*t,l,mid,c);
  55. update(*t+,mid+,r,c);
  56. }
  57. }
  58. }
  59. int query(int t,int l,int r)
  60. {
  61. if (f[t].l==l && f[t].r==r)
  62. {
  63. );
  64. }
  65. ;
  66. f[t].t+=(r-l+)*f[t].add;
  67. f[*t].add+=f[t].add;
  68. f[*t+].add+=f[t].add;
  69. f[t].add=;
  70. *t,l,r);
  71. else
  72. {
  73. *t+,l,r);
  74. else
  75. {
  76. *t,l,mid)+query(*t+,mid+,r);
  77. }
  78. }
  79. }
  80. ];
  81. int Q;
  82. int x,y;
  83. void slove()
  84. {
  85. int len=s.length();
  86. build(,,len);
  87. scanf("%d",&Q);
  88. while (Q--)
  89. {
  90. scanf("%s",sq);
  91. ]=='I')
  92. {
  93. scanf("%d%d",&x,&y);
  94. update(,x,y,);
  95. }
  96. else
  97. {
  98. scanf("%d",&x);
  99. ,x,x);
  100. printf();
  101. }
  102. }
  103. }
  104. int main()
  105. {
  106. int T;
  107. scanf("%d",&T);
  108. ;
  109. while (T--)
  110. {
  111. cin>>s;
  112. printf("Case %d:\n",++t);
  113. slove();
  114. }
  115. ;
  116. }

lightoj1080 线段树的更多相关文章

  1. Lightoj1080 【线段树】

    题意: 给你一个0/1的数组,然后给你n段区间,说这个区间里要反转一次,然后给你Q个询问,问你这个位置是什么: 思路: 我们线段树维护一下就好了额: 其实反转的话,还是算次数是不是,奇偶嘛: #inc ...

  2. bzoj3932--可持久化线段树

    题目大意: 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的 任务用三元组(Si,Ei,Pi)描述,(Si,Ei,Pi)表示任务从第Si秒开始,在第 ...

  3. codevs 1082 线段树练习 3(区间维护)

    codevs 1082 线段树练习 3  时间限制: 3 s  空间限制: 128000 KB  题目等级 : 大师 Master 题目描述 Description 给你N个数,有两种操作: 1:给区 ...

  4. codevs 1576 最长上升子序列的线段树优化

    题目:codevs 1576 最长严格上升子序列 链接:http://codevs.cn/problem/1576/ 优化的地方是 1到i-1 中最大的 f[j]值,并且A[j]<A[i] .根 ...

  5. codevs 1080 线段树点修改

    先来介绍一下线段树. 线段树是一个把线段,或者说一个区间储存在二叉树中.如图所示的就是一棵线段树,它维护一个区间的和. 蓝色数字的是线段树的节点在数组中的位置,它表示的区间已经在图上标出,它的值就是这 ...

  6. codevs 1082 线段树区间求和

    codevs 1082 线段树练习3 链接:http://codevs.cn/problem/1082/ sumv是维护求和的线段树,addv是标记这歌节点所在区间还需要加上的值. 我的线段树写法在运 ...

  7. PYOJ 44. 【HNSDFZ2016 #6】可持久化线段树

    #44. [HNSDFZ2016 #6]可持久化线段树 统计 描述 提交 自定义测试 题目描述 现有一序列 AA.您需要写一棵可持久化线段树,以实现如下操作: A v p x:对于版本v的序列,给 A ...

  8. CF719E(线段树+矩阵快速幂)

    题意:给你一个数列a,a[i]表示斐波那契数列的下标为a[i],求区间对应斐波那契数列数字的和,还要求能够维护对区间内所有下标加d的操作 分析:线段树 线段树的每个节点表示(f[i],f[i-1])这 ...

  9. 【BZOJ-3779】重组病毒 LinkCutTree + 线段树 + DFS序

    3779: 重组病毒 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 224  Solved: 95[Submit][Status][Discuss] ...

随机推荐

  1. 三张图彻底了解Java中字符串的不变性

    转载: 三张图彻底了解Java中字符串的不变性 定义一个字符串 String s = "abcd"; s中保存了string对象的引用.下面的箭头可以理解为"存储他的引用 ...

  2. js中的apply和call API

    借用网上的一个例子: fun.call(this,arg1,arg2,arg3) fun.apply(this,arguments) this.fun(arg1,arg2,arg3) 三种方法等效. ...

  3. HTML5 localStorage and sessionStorage

    转载至:http://blog.csdn.net/fdipzone/article/details/25517615 HTML5 提供两种web存储方法,localStorage 与 sessionS ...

  4. HDU-----(1083)Courses(最大匹配)

    Courses Time Limit: 20000/10000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total S ...

  5. ztree 展示

    1. controller@RequestMapping("/function.htm") public String function(HttpSession session, ...

  6. 阮一峰:RSA算法原理(一)

    今天看到一篇好文章,关于加密算法,收藏了觉得不过瘾,还是自己贴一遍,也能加深一下印象. 原文链接:http://www.ruanyifeng.com/blog/2013/06/rsa_algorith ...

  7. 告别node-forever,拥抱PM2

    告别node-forever,拥抱PM2 返回原文英文原文:Goodbye node-forever,hello PM2 devo.ps团队对JavaScript的迷恋已经不是什么秘密了;node.j ...

  8. chkconfig命令

    chkconfig --list                  #列出系统所有的服务启动情况chkconfig --add xxx           #增加xxx服务chkconfig --de ...

  9. HDU 1688 Sightseeing

    题目链接:Sightseeing 题意:求最短路和比最短路长度+1的所有路径条数. 附代码:用数组记录最短和次短路径的长度和条数,一次更新,直到没有边可以更新. #include <stdio. ...

  10. su和su -和sudo

    1.su和sudo没有切换工作目录和环境变量,只是赋予用户权限, 而su -是真正切换到root登录,工作目录切换到/root,环境变量也同时改变. [root@oc3408554812 home]# ...