HDU 1166 敌兵布阵 树状数组||线段树
http://acm.hdu.edu.cn/showproblem.php?pid=1166
题目大意:
给定n个数的区间N<=50000,还有Q个询问(Q<=40000)求区间和。
每个询问可能增加点k x的值或者减少x。
思路:
原题描述很有爱啊~
树状数组好久没写了~
依旧很熟练,WA了两三次,第一次因为没有输出case,。。。。。。。第二次发现多组数据没有初始化。T^T
~像这种单点修改求区间和的还是用树状数组比较简单~
树状数组:
#include<cstdio>
#include<cstring>
const int MAXN=50000+10;
int sum[MAXN];
inline int lowbit(int x)
{
return x&-x;
} int getsum(int x)
{
int ans=0;
while(x>0)
{
ans+=sum[x];
x-=lowbit(x);
}
return ans;
} void add(int x,int v)
{
while(x<MAXN)
{
sum[x]+=v;
x+=lowbit(x);
}
} int main()
{
//freopen("e:\\input.txt","r",stdin);
int T,kase=1;
scanf("%d",&T);
while(T--)
{
memset(sum,0,sizeof(sum));
int n,t;
scanf("%d",&n);
for(int i=1;i<=n;i++)
{
scanf("%d",&t);
add(i,t);
}
char cmd[10];
printf("Case %d:\n",kase++);
while(scanf("%s",cmd),cmd[0]!='E')
{
int a,b;
scanf("%d%d",&a,&b);
if(cmd[0]=='Q')
printf("%d\n",getsum(b)-getsum(a-1));
else if(cmd[0]=='S')
add(a,-b);
else
add(a,b);
}
}
return 0;
}
线段树:
#include<cstdio>
#include<cstring>
const int MAXN=50000+10;
int sum[MAXN<<2],a[MAXN];
void build(int k,int L,int R)
{
if(L==R) sum[k]=a[L];
else
{
int m=(L+R)/2;
build(k*2,L,m);
build(k*2+1,m+1,R);
sum[k]= sum[k*2]+sum[k*2+1];
}
} int getsum(int k,int L,int R,int a,int b)
{
int m=(L+R)/2,ans=0;
if(a<=L && R<=b) return sum[k];
if(a<=m) ans+=getsum(k*2,L,m,a,b);
if(m<b) ans+=getsum(k*2+1,m+1,R,a,b);
return ans;
} void update(int k,int L,int R,int x,int v)
{
if(L==R) sum[k]+=v;
else
{
int m=(L+R)/2;
if(x<=m) update(k*2,L,m,x,v);
else update(k*2+1,m+1,R,x,v);
sum[k]+=v;
} } int main()
{
// freopen("e:\\input.txt","r",stdin);
int T,kase=1;
scanf("%d",&T);
while(T--)
{
memset(sum,0,sizeof(sum));
int n,t;
scanf("%d",&n);
for(int i=1;i<=n;i++)
scanf("%d",&a[i]); build(1,1,n);
char cmd[10];
printf("Case %d:\n",kase++);
while(scanf("%s",cmd),cmd[0]!='E')
{
int a,b;
scanf("%d%d",&a,&b);
if(cmd[0]=='Q')
printf("%d\n",getsum(1,1,n,a,b));
else if(cmd[0]=='S')
update(1,1,n,a,-b);
else
update(1,1,n,a,b);
}
}
return 0;
}
HDU 1166 敌兵布阵 树状数组||线段树的更多相关文章
- HDU - 1166 敌兵布阵 方法一:(线段树+单点修改,区间查询和) 方法二:利用树状数组
C国的死对头A国这段时间正在进行军事演习,所以C国间谍头子Derek和他手下Tidy又开始忙乎了.A国在海岸线沿直线布置了N个工兵营地,Derek和Tidy的任务就是要监视这些工兵营地的活动情况.由于 ...
- HDU 1166 敌兵布阵 (数状数组,或线段树)
题意:... 析:可以直接用数状数组进行模拟,也可以用线段树. 代码如下: #pragma comment(linker, "/STACK:1024000000,1024000000&quo ...
- hdu 1166 敌兵布阵——(区间和)树状数组/线段树
pid=1166">here:http://acm.hdu.edu.cn/showproblem.php?pid=1166 Input 第一行一个整数T.表示有T组数据. 每组数据第一 ...
- 【线段树I:母题】hdu 1166 敌兵布阵
[线段树I:母题]hdu 1166 敌兵布阵 题目链接:hdu 1166 敌兵布阵 题目大意 C国的死对头A国这段时间正在进行军事演习,所以C国间谍头子Derek和他手下Tidy又開始忙乎了.A国在海 ...
- HDU.1166 敌兵布阵 (线段树 单点更新 区间查询)
HDU.1166 敌兵布阵 (线段树 单点更新 区间查询) 题意分析 加深理解,重写一遍 代码总览 #include <bits/stdc++.h> #define nmax 100000 ...
- hdu 1166 敌兵布阵 线段树 点更新
// hdu 1166 敌兵布阵 线段树 点更新 // // 这道题裸的线段树的点更新,直接写就能够了 // // 一直以来想要进线段树的坑,结果一直没有跳进去,今天算是跳进去吧, // 尽管十分简单 ...
- HDOJ(HDU).1166 敌兵布阵 (ST 单点更新 区间求和)
HDOJ(HDU).1166 敌兵布阵 (ST 单点更新 区间求和) 点我挑战题目 题意分析 根据数据范围和询问次数的规模,应该不难看出是个数据结构题目,题目比较裸.题中包括以下命令: 1.Add(i ...
- 数据结构--树状数组&&线段树--基本操作
随笔目的:方便以后对树状数组(BIT)以及基本线段树的回顾 例题链接:http://acm.hdu.edu.cn/showproblem.php?pid=1166 例题:hdu 1166 敌兵布阵 T ...
- 树状数组 && 线段树应用 -- 求逆序数
参考:算法学习(二)——树状数组求逆序数 .线段树或树状数组求逆序数(附例题) 应用树状数组 || 线段树求逆序数是一种很巧妙的技巧,这个技巧的关键在于如何把原来单纯的求区间和操作转换为 求小于等于a ...
- hdu1394(枚举/树状数组/线段树单点更新&区间求和)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1394 题意:给出一个循环数组,求其逆序对最少为多少: 思路:对于逆序对: 交换两个相邻数,逆序数 +1 ...
随机推荐
- C#中一些字符串操作的经常使用使用方法
概述 本篇主要解说,字符串string的基本操作知识 倒序输出 string str = Console.ReadLine(); for (int i = str.Length - 1; i > ...
- Java Swing设置主窗体位置居中方法
01.第一种方法 int windowWidth = frame.getWidth(); //获得窗体宽 int windowHeight = frame.getHeight(); //获得窗体高 ...
- java 链接server上的 mongodb 出现 connect time out 问题
异常信息 十二月 22, 2014 5:27:58 下午 com.mongodb.DBTCPConnector initDirectConnection 警告: Exception executing ...
- SQL Server字符串分割函数
- c++值传递,指针传递,引用传递以及指针与引用的区别
值传递: 形参是实参的拷贝,改变形参的值并不会影响外部实参的值.从被调用函数的角度来说,值传递是单向的(实参->形参),参数的值只能传入, 不能传出.当函数内部需要修改参数,并且不希望这个改变影 ...
- offSet和client和scroll
这三个是是js盒模型属性 client clientWidth 内容宽度加上左右padding clientHeight 内容高度加上上下padding clientTop 上边框的宽度 client ...
- 阿里云 Ubuntu14.04 升级 python3.4 到 python 3.5/6
买的阿里云服务器给的系统是Ubuntu14.04,里面装的Python3版本是Python3.4,本来也没什么,但是这个版本的Python安装flask和django各种报错,所以只好升级Python ...
- MVC—实现ajax+mvc异步获取数据
之前写过ajax和一般处理程序的结合实现前后台的数据交换的博客,如今做系统用到了MVC,同一时候也用到了异步获取数据. ajax+一般处理程序与MVC+ajax原理是一样的在"URL&quo ...
- 源代码编译安装CloudStack 4.2
基于CentOS 6.4安装CloudStack 环境配置 # yum -y update # yum -y upgrade 安装NTP,jdk 1.7, tomcat 6, mysql,git等服务 ...
- js36---函数嵌套
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/stri ...