hdu1166-敌兵布阵(线段树)
http://acm.hdu.edu.cn/showproblem.php?pid=1166
区间更新,区间求和
// File Name: hdu1166.cpp
// Author: bo_jwolf
// Created Time: 2013年08月16日 星期五 11时27分03秒 #include<vector>
#include<list>
#include<map>
#include<set>
#include<deque>
#include<stack>
#include<bitset>
#include<algorithm>
#include<functional>
#include<numeric>
#include<utility>
#include<sstream>
#include<iostream>
#include<iomanip>
#include<cstdio>
#include<cmath>
#include<cstdlib>
#include<cstring>
#include<ctime> using namespace std; #define lson l , mid , rt << 1
#define rson mid + 1 , r , rt << 1 | 1 const int maxn = 55555 ;
//int sum[ maxn << 2 ] ; struct node
{
int sum ;
}tree[ maxn << 2 ] ; void PushUp( int rt )
{
tree[ rt ].sum = tree[ rt << 1 ].sum + tree[ (rt << 1 | 1 ) ].sum ;
}
void build( int l , int r , int rt )
{
if( l == r )
{
scanf( "%d" , &tree[ rt ].sum );
return ;
}
int mid = ( l + r ) >> 1 ;
build( lson ) ;
build( rson ) ;
PushUp( rt ) ;
} void update( int p , int add , int l , int r , int rt )
{
if( l == r )
{
tree[ rt ].sum += add ;
return ;
}
int mid = ( l + r ) >> 1 ;
if( p <= mid )
update( p , add , lson ) ;
else
update( p , add , rson ) ;
PushUp( rt ) ;
} int query( int L , int R , int l , int r , int rt )
{
if( L <= l && r <=R )
{
return tree[ rt ].sum ;
}
int mid = ( l + r ) >> 1 ;
int ret = 0 ;
if( L <= mid )
ret += query( L , R , lson ) ;
if( R > mid )
ret += query( L , R , rson ) ;
return ret ;
} int main()
{
int T , n ;
scanf( "%d" , &T ) ;
for( int cas = 1 ; cas <= T ; ++cas )
{
printf( "Case %d:\n" , cas ) ;
scanf( "%d" , &n ) ;
build( 1 , n , 1 ) ;
char op[ 10 ] ;
while( scanf( "%s" , op ) )
{
if( op[ 0 ] == 'E' )
break ;
int a , b ;
scanf( "%d%d" , &a , &b ) ;
if( op[ 0 ] == 'Q' )
printf( "%d\n" , query( a , b , 1 , n , 1 ) ) ;
else if( op[ 0 ] == 'S' )
update( a , -b , 1 , n , 1 ) ;
else
update( a , b , 1 , n , 1 ) ;
}
}
return 0;
}
hdu1166-敌兵布阵(线段树)的更多相关文章
- HDU-1166敌兵布阵(线段树)
敌兵布阵 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submissi ...
- hdu1166 敌兵布阵(线段树 求区间和 更新点)
敌兵布阵 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submi ...
- hdu1166 敌兵布阵 线段树(区间更新)
敌兵布阵 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
- HDU1166 敌兵布阵(线段树)
C国的死对头A国这段时间正在进行军事演习,所以C国间谍头子Derek和他手下Tidy又开始忙乎了.A国在海岸线沿直线布置了N个工兵营地,Derek和Tidy的任务就是要监视这些工兵营地的活动情况.由于 ...
- 【生活没有希望】hdu1166敌兵布阵 线段树
线段树水题刷刷,生活没有希望 最近看到代码跟树状数组差不多短的非递归线段树,常数也很小——zkw线段树 于是拿道水题练练手 短到让人身无可恋 ;pos;pos/=) a[pos]+=x;} ,ans= ...
- HDU1166 敌兵布阵 线段树详解
题解: 更新是线段树的单点更新,简单一点. 有50000个阵营,40000查询,用普通数组肯定超时.区间求和和区间查询问题用线段树最好不过了. 先说说什么是线段树. 区间[1,10]用树的方法存起来, ...
- HDU1166 敌兵布阵 —— 线段树单点修改
题目链接:https://vjudge.net/problem/HDU-1166 C国的死对头A国这段时间正在进行军事演习,所以C国间谍头子Derek和他手下Tidy又开始忙乎了.A国在海岸线沿直线布 ...
- HDU1166 敌兵布阵 [线段树模板]
题意:在序列中修改单点和查询区间和 #include<iostream> #include<cstdio> #include<cstring> #define ls ...
- HDU.1166 敌兵布阵 (线段树 单点更新 区间查询)
HDU.1166 敌兵布阵 (线段树 单点更新 区间查询) 题意分析 加深理解,重写一遍 代码总览 #include <bits/stdc++.h> #define nmax 100000 ...
- hdu 1166 敌兵布阵 线段树 点更新
// hdu 1166 敌兵布阵 线段树 点更新 // // 这道题裸的线段树的点更新,直接写就能够了 // // 一直以来想要进线段树的坑,结果一直没有跳进去,今天算是跳进去吧, // 尽管十分简单 ...
随机推荐
- BZOJ 1123 BLO
tarjan求割点计算答案.注意不是每一棵子树都算答案.开个变量记一下. #include<iostream> #include<cstdio> #include<cst ...
- 20160202.CCPP体系详解(0012天)
内容概要:C语言控制语句题库.doc 第三章 控制语句 一.选择题 1. 以下语句中无限循环语句是[B]. A)for(;2&5;); B)while(1,2,3); -> while( ...
- 【英语】Bingo口语笔记(58) - blow系列
- OpenVz一键安装openvpn
# !/bin/sh # OPENVPN SERVER CONFIGURATION echo "####################################" echo ...
- Android下实现win8的按钮点击效果
原理就是自定义一个imageButton,实现动画效果 demo源码下载地址: 请戳这里----------------> 关于回弹张力的效果扩展,可以参考Facebook的开源动画库rebo ...
- SQL利用Case When Then多条件判断
CASE WHEN 条件1 THEN 结果1 WHEN 条件2 THEN 结果2 WHEN 条件3 THEN 结果3 WHEN 条件4 THEN 结果4 ....... ...
- Windows 8 电话激活密钥。(更新至 2013-07-21)
MAK密钥,可用于电话激活专业版&企业版,2013.7.21 更新,共22枚: slmgr.vbs -ipk MQJNQ-G2TKM-YJP7W-CCXVY-VQR92slmgr.vbs -i ...
- Readonly与const初识
对于readonly和const,很多人无法具体区分,不清楚它们的具体使用场合:现在我们分析它们之间的区别和使用场合. const是一个编译期常量:const只能用于修饰基元类型.枚举类型或者字符串类 ...
- mongo 安装
mongo 安装: 1.按照 https://docs.mongodb.com/manual/tutorial/install-mongodb-on-red-hat/ 安装 2.安装成功后创建用户 d ...
- Ubuntu 16.04 TensorFlow CPU 版本安装
1.下载Anaconda,官方网站.我下载的时Python 2.7 64bit版本: 2.安装执行命令 bash Anaconda2-4.2.0-Linux-x86_64.sh 设置好目录后等 ...