Input
第一行一个整数T,表示有T组数据。
每组数据第一行一个正整数N(N<=50000),表示敌人有N个工兵营地,接下来有N个正整数,第i个正整数ai代表第i个工兵营地里开始时有ai个人(1<=ai<=50)。
接下来每行有一条命令,命令有4种形式:
(1)
Add i j,i和j为正整数,表示第i个营地增加j个人(j不超过30)
(2)Sub i j
,i和j为正整数,表示第i个营地减少j个人(j不超过30);
(3)Query i j
,i和j为正整数,i<=j,表示询问第i到第j个营地的总人数;
(4)End
表示结束,这条命令在每组数据最后出现;
每组数据最多有40000条命令
 
Output
对第i组数据,首先输出“Case
i:”和回车,
对于每个Query询问,输出一个整数并回车,表示询问的段中的总人数,这个数保持在int以内。
 
Sample Input
1
10
1 2 3 4 5 6 7 8 9 10
Query 1 3
Add 3 6
Query 2 7
Sub 10 2
Add 6 3
Query 3 10
End
 
#include<cstdio>
#include<algorithm>
#include<cstring>
#define ls x<<1
#define rs x<<1|1
using namespace std;
const int N=;
int tr[N<<];
int T,Case,n; void bt(int l,int r,int x)
{
if (l==r)
{
int dat;
scanf ("%d",&dat);
tr[x]=dat; return;
}
int mid=(l+r)>>;
bt(l,mid,ls);
bt(mid+,r,rs);
tr[x]=tr[ls]+tr[rs];
return;
} void add(int q,int a,int l,int r,int x)
{
if (l==r)
{
tr[x]+=a;
return;
}
int mid=(l+r)>>;
if (q<=mid) add(q,a,l,mid,ls);
else add(q,a,mid+,r,rs);
tr[x]=tr[ls]+tr[rs];
return;
} void sub(int q,int a,int l,int r,int x)
{
if (l==r)
{
tr[x]-=a;
return ;
}
int mid=(l+r)>>;
if (q<=mid) sub(q,a,l,mid,ls);
else sub(q,a,mid+,r,rs);
tr[x]=tr[ls]+tr[rs];
return ;
} int que(int ql,int qr,int l,int r,int x)
{
if (ql<=l && qr>=r)
{
return tr[x];
}
int mid=(l+r)>>,ans=;
if (ql<=mid) ans+=que(ql,qr,l,mid,ls);
if (qr>mid) ans+=que(ql,qr,mid+,r,rs);
return ans;
} int main()
{
scanf ("%d",&T);
while (T--)
{
Case++;
printf("Case %d:\n",Case);
memset(tr,,sizeof(tr));
scanf ("%d",&n);
bt(,n,);
char s[];
while ()
{
getchar();
scanf ("%s",s);
if (s[]=='Q')
{
int l,r;
scanf ("%d%d",&l,&r);
printf("%d\n",que(l,r,,n,));
}
else if (s[]=='A')
{
int x,y;
scanf ("%d%d",&x,&y);
add(x,y,,n,);
}
else if (s[]=='S')
{
int x,y;
scanf ("%d%d",&x,&y);
sub(x,y,,n,);
}
else break;
}
}
return ;
}
Sample Output
Case 1:
6
33
59
 
 
十分基础的线段树模板,存一下。
 
 

HDU 1166 敌兵布阵 (线段树单点修改和区间和查询)的更多相关文章

  1. HDU 1166 敌兵布阵 <线段树 单点修改 区间查询>

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

  2. HDU.1166 敌兵布阵 (线段树 单点更新 区间查询)

    HDU.1166 敌兵布阵 (线段树 单点更新 区间查询) 题意分析 加深理解,重写一遍 代码总览 #include <bits/stdc++.h> #define nmax 100000 ...

  3. HDU 1166 敌兵布阵(线段树单点更新,板子题)

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

  4. HDU 1166 敌兵布阵(线段树单点更新)

    敌兵布阵 单点更新和区间更新还是有一些区别的,应该注意! [题目链接]敌兵布阵 [题目类型]线段树单点更新 &题意: 第一行一个整数T,表示有T组数据. 每组数据第一行一个正整数N(N< ...

  5. HDU 1166 敌兵布阵(线段树单点更新,区间查询)

    描述 C国的死对头A国这段时间正在进行军事演习,所以C国间谍头子Derek和他手下Tidy又开始忙乎了.A国在海岸线沿直线布置了N个工兵营地,Derek和Tidy的任务就是要监视这些工兵营地的活动情况 ...

  6. HDU 1166 敌兵布阵 线段树单点更新求和

    题目链接 中文题,线段树入门题,单点更新求和,建一棵树就可以了. #include <iostream> #include <cstdio> #include <cmat ...

  7. 【原创】hdu 1166 敌兵布阵(线段树→单点更新,区间查询)

    学习线段树的第三天...真的是没学点啥好的,又是一道水题,纯模板,我个人觉得我的线段树模板还是不错的(毕竟我第一天相当于啥都没学...找了一整天模板,对比了好几个,终于找到了自己喜欢的类型),中文题目 ...

  8. hdu 1166 敌兵布阵 线段树 点更新

    // hdu 1166 敌兵布阵 线段树 点更新 // // 这道题裸的线段树的点更新,直接写就能够了 // // 一直以来想要进线段树的坑,结果一直没有跳进去,今天算是跳进去吧, // 尽管十分简单 ...

  9. HDU 1754 线段树 单点跟新 HDU 1166 敌兵布阵 线段树 区间求和

    I Hate It Time Limit: 9000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total ...

  10. hdu 1166 敌兵布阵 线段树区间修改、查询、单点修改 板子题

    题目链接:敌兵布阵 题目: C国的死对头A国这段时间正在进行军事演习,所以C国间谍头子Derek和他手下Tidy又开始忙乎了.A国在海岸线沿直线布置了N个工兵营地,Derek和Tidy的任务就是要监视 ...

随机推荐

  1. RAM和ROM和Flash ROM的区别

    转;http://openedv.com/thread-81182-1-1.html                           http://www.sohu.com/a/112676146 ...

  2. CSS3进度条 和 HTML5 Canvas画圆环

    看到一些高大上的进度条插件,然后想自己用CSS写.经过搜索资料之后,终于成功了.为了以后方便拿来用,或者复习.将代码贴出. HTML代码: 只需要两个div,外面的为一个有border的div id为 ...

  3. 2个YUV视频拼接技术

    http://blog.csdn.net/huahuahailang/article/details/9040847 2个YUV视频拼接技术 http://zhongcong386.blog.163. ...

  4. iostat命令具体解释——linux性能分析

    之前总结uptime和free命令,今天继续来总结一下iostat.给自己留个笔记.同一时候也希望对大家实用. 版本号信息: sysstat version 9.0.4           (C) S ...

  5. jdbc 链接池的优化

    package cn.itcast.jdbc.datasourse; import java.sql.Connection;import java.sql.DriverManager;import j ...

  6. EF获取DbContext中已注册的所有实体类型

    /// <summary> /// 获取DbContext中已注册的实体类型 /// </summary> /// <typeparam name="T&quo ...

  7. Layout布局位置

    - - GUILayout 这个本身就是用于自动布局的. 不用给定位置的,这也是它与GUI的区别所在.通常默认开始的位置是屏幕的左上角. 当然你也可以限定开始自动布局的位置.用 GUILayout.B ...

  8. python opener代理

    链接:http://www.jb51.net/article/46495.htm https://www.cnblogs.com/cunyusup/p/7341829.html

  9. php如何在原来的时间上加一天?一小时?

    <?php echo "今天:",date('Y-m-d H:i:s'),"<br>"; echo "明天:",date( ...

  10. LR中select next row和update value on的设置

    LR的参数的取值,和select next row和update value on的设置都有密不可分的关系.下表给出了select next row和update value on不同的设置,对于LR ...