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 ...
随机推荐
- javaWeb自己定义可排序过滤器注解,解决Servlet3.0下@WebFilter注解无法排序问题
com.lwl.anno 凝视类型 @WebFilterSort 须要用的jar包 http://download.csdn.net/detail/u013202238/9431110 用该注解注冊的 ...
- Transport Tablespace Set(三) ----transport single tablespace
源端字符集与endian查看: SQL> select userenv('language') from dual; USERENV('LANGUAGE') SIMPLIFIED CHINESE ...
- 论Nim中的 proc 和 method
在Nim中.proc 是定义过程的keyword.method 是定义方法的keyword.它们之间根本的差别是proc定义的过程是静态绑定.method定义的方法是动态绑定.谈到静态绑定.动态绑定又 ...
- jquery13 attr() prop() val() addClass()等 : 对元素属性的操作
<!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" content ...
- region实现大纲效果
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...
- vue --- watch 高级用法
假设有如下代码: <div> <p>FullName: {{fullName}}</p> <p>FirstName: <input type=&q ...
- 暑假集训-二分图,网络流,2-SAT
匈牙利算法DFS bool dfs(int u){ ; i <= n; i++){ if(a[u][i] && !visit[i]){ visit[i] = true; || d ...
- c# List集合学习
1---集合,可以理解成容器 泛型集合 非泛型集合2---使用集合用到的命名空间 using System.Collections.Generic;3---集合是如何来的?集合的前辈是数组,数组在内存 ...
- 搭建 GIT 服务器教程
- yum---rpm软件包管理器
yum命令是在Fedora和RedHat以及SUSE中基于rpm的软件包管理器,它可以使系统管理人员交互和自动化地更细与管理RPM软件包,能够从指定的服务器自动下载RPM包并且安装,可以自动处理依赖性 ...