HDU 1166 敌兵布阵 线段树区间求和 更改
水
#include<iostream>
#include<string>
#include<algorithm>
#include<cstdlib>
#include<cstdio>
#include<set>
#include<map>
#include<vector>
#include<cstring>
#include<stack>
#include<cmath>
#include<queue>
#include <bits/stdc++.h>
using namespace std;
#define INF 0x3f3f3f3f
#define ll long long
#define clc(a,b) memset(a,b,sizeof(a))
const int maxn=; int ans;
struct node
{
int left,right,sum;
int mid()
{
return (left+right)>>;
}
}tree[maxn*]; void build_tree(int l,int r,int o)
{
tree[o].left=l;
tree[o].right=r;
if(l==r)
{
scanf("%d",&tree[o].sum);
return ;
}
int mid=tree[o].mid();
build_tree(l,mid,o<<);
build_tree(mid+,r,o<<|);
tree[o].sum=tree[o<<].sum+tree[o<<|].sum;
} void query(int l,int r,int o,int L,int R)
{
if(L<=l&&r<=R)
{
ans+=tree[o].sum;
return ;
}
int mid=tree[o].mid();
if(R<=mid)
query(l,mid,o<<,L,R);
else if(L>mid)
query(mid+,r,o<<|,L,R);
else
{
query(l,mid,o<<,L,R);
query(mid+,r,o<<|,L,R);
}
} void update(int l,int r,int o,int pos,int add)
{
if(l==r)
{
tree[o].sum+=add;
return ;
}
int mid=tree[o].mid();
if(pos<=mid)
{
update(l,mid,o<<,pos,add);
}
else
update(mid+,r,o<<|,pos,add);
tree[o].sum=tree[o<<].sum+tree[o<<|].sum;
} int main()
{
int t,n,cnt;
int a,b;
char str[];
cnt=;
scanf("%d",&t);
while(t--)
{
scanf("%d",&n);
build_tree(,n,);
printf("Case %d:\n",cnt++);
while(scanf("%s",str))
{
if(str[]=='E')
break;
scanf("%d%d",&a,&b);
if(str[]=='Q')
{
ans=;
query(,n,,a,b);
printf("%d\n",ans);
}
else if(str[]=='A')
update(,n,,a,b);
else
update(,n,,a,-b);
}
}
return ;
}
HDU 1166 敌兵布阵 线段树区间求和 更改的更多相关文章
- HDU 1754 线段树 单点跟新 HDU 1166 敌兵布阵 线段树 区间求和
I Hate It Time Limit: 9000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total ...
- hdu 1166 敌兵布阵 线段树区间修改、查询、单点修改 板子题
题目链接:敌兵布阵 题目: C国的死对头A国这段时间正在进行军事演习,所以C国间谍头子Derek和他手下Tidy又开始忙乎了.A国在海岸线沿直线布置了N个工兵营地,Derek和Tidy的任务就是要监视 ...
- hdu 1116 敌兵布阵 线段树 区间求和 单点更新
线段树的基本知识可以先google一下,不是很难理解 线段树功能:update:单点增减 query:区间求和 #include <bits/stdc++.h> #define lson ...
- HDU.1166 敌兵布阵 (线段树 单点更新 区间查询)
HDU.1166 敌兵布阵 (线段树 单点更新 区间查询) 题意分析 加深理解,重写一遍 代码总览 #include <bits/stdc++.h> #define nmax 100000 ...
- hdu 1166 敌兵布阵 线段树 点更新
// hdu 1166 敌兵布阵 线段树 点更新 // // 这道题裸的线段树的点更新,直接写就能够了 // // 一直以来想要进线段树的坑,结果一直没有跳进去,今天算是跳进去吧, // 尽管十分简单 ...
- HDU 1166 敌兵布阵(线段树单点更新,板子题)
敌兵布阵 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submi ...
- HDU 1166 敌兵布阵(线段树单点更新)
敌兵布阵 单点更新和区间更新还是有一些区别的,应该注意! [题目链接]敌兵布阵 [题目类型]线段树单点更新 &题意: 第一行一个整数T,表示有T组数据. 每组数据第一行一个正整数N(N< ...
- HDU 1166 敌兵布阵 <线段树 单点修改 区间查询>
敌兵布阵 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
- hdu 1166 敌兵布阵 (线段树、单点更新)
敌兵布阵Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submiss ...
随机推荐
- About building ant & install ant on centos7 {ant source code 1.94}
hamcrest-junit-2.0.0.0.jar java-hamcrest-2.0.0.0.jar copy to ant-sourceCodeDir/lib/o ...
- 创建一个.bat文件,用于打开某个路径下的文件
- Linux命令总结(转载)
转子:http://www.cnblogs.com/CGDeveloper/archive/2011/05/27/2060009.html 昨天看了一个教程,关于Linux命令的,本来以为当是复习随便 ...
- Objective-c开发中混合使用ARC
首选“Compile Sources”的位置: 选中工程->TARGETS->相应的target然后选中右侧的“Build Phases”,向下就找到“Compile Sources”了. ...
- [Linux发行版] 常见Linux系统下载
本专题页汇总最受欢迎的Linux发行版基本介绍和下载地址,如果您是一位刚接触Linux的新手,这里的介绍可能对您有所帮助,如果您是以为Linux使用前辈,也可以在评论处留下您宝贵意见和经验,以便让更多 ...
- VC项目配置基础以及快捷键(收藏)
来自http://blog.csdn.net/phunxm/article/details/5082488 一.IDE基础配置 1.字体 VC6中“Tools→Options→Format→Font” ...
- 图像混合学习。运用加权函数,学习opencv基础操作
{ cout<< } { cout<< } ,,logoImage.c ...
- shell 流程控制
for循环: #!/bin/bash for file in $(ls /ect) do echo $file done
- Spring 数据源配置二:多数据源
通过上一节 Spring 数据源配置一: 单一数据源 我们了解单一数据源的配置, 这里我们继续多个数据源的配置 如下(applicationContent.xml 内容) 一: Spring ...
- sizeof()和strlen()在求字符串长度时的差别
sizeof()函数输出字符串长度时会把结束符计算在内: strlen()函数输出字符串长度时不会把结束符计算在内. 如图: