#include<iostream>
using namespace std;
const int MAX=;
int tree[(MAX+)*];//n个叶子就有2*n-4*n个节点
int a[MAX+];
int n;
void getup(int root){
return void(tree[root]=tree[root*]+tree[root*+]);//两个孩子分别是root*2 和root*2+1
}
void btree(int l,int r,int root){//建树
if(l==r){
tree[root]=a[l];
return ;
}
int mid=(l+r)>>;
btree(l,mid,root*);
btree(mid+,r,root*+);//因为向下取整 mid必须加一 不然结束不了
getup(root);
}
int myquery(int l,int r,int L,int R,int root){//整个的思想是区间和肯定可以用二分的区间表示
if(l<=L&&r>=R) return tree[root];
int mid=(L+R)>>;
long long sum=;
if(l<=mid) sum+=myquery(l,r,L,mid,root*);//两边相加
if(r>mid) sum+=myquery(l,r,mid+,R,root*+);
return sum;
}
void add(int i,int value,int l,int r,int root){//重点!! 更新的过程
if(l==r) {tree[root]+=value;return ;}
int mid=(l+r)>>;
if(i<=mid) add(i,value,l,mid,root*);
else add(i,value,mid+,r,root*+);
getup(root);
}
int main(){
int t;
cin>>t;
int i=;
while(i<=t){
int flag=;
scanf("%d",&n);
for(int i=;i<=n;i++)
scanf("%d",&a[i]);
btree(,n,);
char ss[];
while(~scanf("%s",ss)){
if(ss[]=='A'){
int i,value;
scanf("%d %d",&i,&value);
add(i,value,,n,);
}
if(ss[]=='S'){
int i,value;
scanf("%d %d",&i,&value);
add(i,-*value,,n,);
}
if(ss[]=='Q'){
int a ,b;
scanf("%d%d",&a,&b);
if(flag){printf("Case %d:\n",i);flag=;}
printf("%d\n",myquery(a,b,,n,));
}
if(ss[]=='E') break;
}
i++;
}
}

题目链接:acm.hdu.edu.cn/status.php?user=YZBPXX&pid=1166&status=5

hdu 1166 线段树 奇兵布阵的更多相关文章

  1. 敌兵布阵 HDU 1166 线段树

    敌兵布阵 HDU 1166 线段树 题意 这个题是用中文来描写的,很简单,没什么弯. 解题思路 这个题肯定就是用线段树来做了,不过当时想了一下可不可用差分来做,因为不熟练就还是用了线段树来做,几乎就是 ...

  2. hdu 1166 线段树(sum+单点修改)

    敌兵布阵 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submi ...

  3. A - 敌兵布阵 HDU - 1166 线段树(多点修改当单点修改)

    线段树板子题练手用 #include<cstdio> using namespace std; ; int a[maxn],n; struct Node{ int l,r; long lo ...

  4. HDU(1166),线段树模板,单点更新,区间总和

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1166 第一次做线段树,帆哥的一句话,我记下来了,其实,线段树就是一种处理数据查询和更新的手段. 然后, ...

  5. hdu 1166线段树 单点更新 区间求和

    敌兵布阵 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submis ...

  6. hdu 1166 线段树单点更新

    等线段树复习完再做个总结 1101 2 3 4 5 6 7 8 9 10Query 1 3Add 3 6Query 2 7Sub 10 2Add 6 3Query 3 10End Case 1:633 ...

  7. hdu 1166 线段树(单点增减 区间求和)

    Sample Input1101 2 3 4 5 6 7 8 9 10Query 1 3Add 3 6Query 2 7Sub 10 2Add 6 3Query 3 10End Sample Outp ...

  8. HDU 1166 线段树模板&树状数组模板

    HDU1166 上好的线段树模板&&树状数组模板 自己写的第一棵线段树&第一棵树状数组 莫名的兴奋 线段树: #include <cstdio> using nam ...

  9. hdu 1166 线段树 区间求和 +单点更新 CD模板

    题目链接 敌兵布阵 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total S ...

随机推荐

  1. java实现spark常用算子之Reduce

    import org.apache.spark.SparkConf;import org.apache.spark.api.java.JavaRDD;import org.apache.spark.a ...

  2. 深入理解hive之事务处理

    事务的四个特性 1.automicity:原子性 2.consistency:一致性 3. isolation:独立性 4.durability:持久性 5.支持事务有几个条件需要满足:1.所有的事务 ...

  3. 03 Go语言特性

    一.基本注意事项 1.转义字符 \t 一个制表符,代表一次tab \n 换行符 \\ 转义代表 \ \" 转义代表 " \r 一个回车,从当前行的最前面开始输出,会覆盖以前的内容, ...

  4. vue-$watch属性方法

    特性 https://www.cnblogs.com/widgetbox/p/8954162.html https://segmentfault.com/a/1190000012948175?utm_ ...

  5. JS中的SRC

    当应用SRC属性时,首先需要创建一个JS文件.为什么不在此文件中使用<script>标记?您可以直接使用输出语句吗?我会分享我的报告一个答案 JS文件不是HTM文件,因此内部不能有HTML ...

  6. Python字符串、组合数据类型练习

    一.Python字符串练习 1.http://news.gzcc.cn/html/2017/xiaoyuanxinwen_1027/8443.html 取得校园新闻的编号. (这个方法就很多了,一般方 ...

  7. TensorFlow中CNN的两种padding方式“SAME”和“VALID”

    来源 dilation_rate为一个可选的参数,默认为1,这里我们可以先不管它. 整理一下,对于"VALID",输出的形状计算如下: new_height=new_width=⌈ ...

  8. Qt设置按钮为圆形

    通过Qt 的样式表实现圆形按钮,其也可以实现圆角按钮,当然也可以使用其他的方式,比如说,通过派生按钮类使用绘图事件,进行一个图形的绘制,或者是通过自定义一个类,通过信号与槽的机制与绘图事件的配合也能实 ...

  9. pandas中的Series

    我们使用pandas经常会用到其下面的一个类:Series,那么这个类都有哪些方法呢?另外Series和DataFrame都继承了NDFrame这个类,df.to_sql()这个方法其实就是NDFra ...

  10. IPC之shm.c源码解读

    // SPDX-License-Identifier: GPL-2.0 /* * linux/ipc/shm.c * Copyright (C) 1992, 1993 Krishna Balasubr ...