随笔目的:方便以后对树状数组(BIT)以及基本线段树的回顾

例题链接:http://acm.hdu.edu.cn/showproblem.php?pid=1166

例题:hdu 1166

敌兵布阵

                          Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)
Problem Description
  C国的死对头A国这段时间正在进行军事演习,所以C国间谍头子Derek和他手下Tidy又开始忙乎了。A国在海岸线沿直线布置了N个工兵营地,Derek和Tidy的任务就是要监视这些工兵营地的活动情况。由于采取了某种先进的监测手段,所以每个工兵营地的人数C国都掌握的一清二楚,每个工兵营地的人数都有可能发生变动,可能增加或减少若干人手,但这些都逃不过C国的监视。 中央情报局要研究敌人究竟演习什么战术,所以Tidy要随时向Derek汇报某一段连续的工兵营地一共有多少人,例如Derek问:“Tidy,马上汇报第3个营地到第10个营地共有多少人!”Tidy就要马上开始计算这一段的总人数并汇报。但敌兵营地的人数经常变动,而Derek每次询问的段都不一样,所以Tidy不得不每次都一个一个营地的去数,很快就精疲力尽了,Derek对Tidy的计算速度越来越不满:"你个死肥仔,算得这么慢,我炒你鱿鱼!”Tidy想:“你自己来算算看,这可真是一项累人的工作!我恨不得你炒我鱿鱼呢!”无奈之下,Tidy只好打电话向计算机专家Windbreaker求救,Windbreaker说:“死肥仔,叫你平时做多点acm题和看多点算法书,现在尝到苦果了吧!”Tidy说:"我知错了。。。"但Windbreaker已经挂掉电话了。Tidy很苦恼,这么算他真的会崩溃的,聪明的读者,你能写个程序帮他完成这项工作吗?不过如果你的程序效率不够高的话,Tidy还是会受到Derek的责骂的.
 
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以内。
树状数组(BIT)代码:
 #include "stdio.h"
#include "string.h"
#define N 50005 int n;
int a[N],c[N]; int lowbit(int x){ return x&(-x); } int Query(int x)
{
int sum = ;
for(int i=x; i>; i-=lowbit(i))
sum += c[i];
return sum;
} int main()
{
int T;
int i,j,Case=;
char str[];
scanf("%d",&T);
while(T--)
{
scanf("%d",&n);
memset(a,,sizeof(a));
memset(c,,sizeof(c));
for(i=; i<=n; i++)
{
scanf("%d",&a[i]);
for(j=i; j<=n; j+=lowbit(j))
c[j] += a[i];
}
printf("Case %d:\n",Case++);
while(scanf("%s",str),strcmp(str,"End")!=)
{
scanf("%d %d",&i,&j);
if(strcmp(str,"Add")==)
{
a[i] += j;
for(int k=i; k<=n; k+=lowbit(k))
c[k] += j;
}
else if(strcmp(str,"Sub")==)
{
a[i] -= j;
for(int k=i; k<=n; k+= lowbit(k))
c[k] -= j;
}
else
printf("%d\n",Query(j) - Query(i-));
}
}
return ;
}
线段树代码:
 #include "iostream"
#include "cstdio"
#include "cstring"
using namespace std;
#define N 50005
struct point
{
int l,r;
int sum;
}Tree[N*]; void Build(int t,int l,int r)
{
Tree[t].l = l;
Tree[t].r = r;
Tree[t].sum = ;
if(Tree[t].l == Tree[t].r)
{
scanf("%d",&Tree[t].sum);
return ;
}
int mid = (l+r)/;
Build(t<<,l,mid);
Build(t<<|,mid+,r);
Tree[t].sum = Tree[t<<].sum + Tree[t<<|].sum;
} void Add(int t,int l,int r)
{
if(Tree[t].l==Tree[t].r && Tree[t].l==l)
{
Tree[t].sum += r;
return ;
}
int mid = (Tree[t].l+Tree[t].r)/;
if(l <= mid)
Add(t<<,l,r);
else
Add(t<<|,l,r);
Tree[t].sum = Tree[t<<].sum + Tree[t<<|].sum;
}
int Query(int t,int l,int r)
{
if(Tree[t].l==l && Tree[t].r==r)
{
return Tree[t].sum;
}
int mid = (Tree[t].l + Tree[t].r)/;
if(r <= mid)
return Query(t<<,l,r);
else if(l > mid)
return Query(t<<|,l,r);
else
return Query(t<<,l,mid) + Query(t<<|,mid+,r);
} int main()
{
int T;
int iCase = ;
scanf("%d",&T);
while(T--)
{
int n;
iCase++;
printf("Case %d:\n",iCase);
scanf("%d",&n);
Build(,,n);
char str[];
getchar();
while(scanf("%s",str) && strcmp(str,"End")!=)
{
int x,y;
scanf("%d %d",&x,&y);
if(strcmp(str,"Query")==)
{
printf("%d\n",Query(,x,y));
}
else if(strcmp(str,"Add")==)
{
Add(,x,y);
}
else if(strcmp(str,"Sub")==)
{
Add(,x,-y); }
}
}
return ;
}
												

数据结构--树状数组&&线段树--基本操作的更多相关文章

  1. 洛谷P2414 阿狸的打字机 [NOI2011] AC自动机+树状数组/线段树

    正解:AC自动机+树状数组/线段树 解题报告: 传送门! 这道题,首先想到暴力思路还是不难的,首先看到y有那么多个,菜鸡如我还不怎么会可持久化之类的,那就直接排个序什么的然后按顺序做就好,这样听说有7 ...

  2. 树状数组 && 线段树应用 -- 求逆序数

    参考:算法学习(二)——树状数组求逆序数 .线段树或树状数组求逆序数(附例题) 应用树状数组 || 线段树求逆序数是一种很巧妙的技巧,这个技巧的关键在于如何把原来单纯的求区间和操作转换为 求小于等于a ...

  3. hdu1394(枚举/树状数组/线段树单点更新&区间求和)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1394 题意:给出一个循环数组,求其逆序对最少为多少: 思路:对于逆序对: 交换两个相邻数,逆序数 +1 ...

  4. hdu 1166:敌兵布阵(树状数组 / 线段树,入门练习题)

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

  5. hdu 5147 Sequence II【树状数组/线段树】

    Sequence IITime Limit: 5000/2500 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Problem ...

  6. 「CodePlus 2017 11 月赛」Yazid 的新生舞会(树状数组/线段树)

    学习了新姿势..(一直看不懂大爷的代码卡了好久T T 首先数字范围那么小可以考虑枚举众数来计算答案,设当前枚举到$x$,$s_i$为前$i$个数中$x$的出现次数,则满足$2*s_r-r > 2 ...

  7. 【洛谷4396/BZOJ3236】[AHOI2013]作业(莫队+分块/树状数组/线段树)

    题目: 洛谷4396 BZOJ3236(权限) 这题似乎BZOJ上数据强一些? 分析: 这题真的是--一言难尽 发现题面里没说权值的范围,怕出锅就写了离散化.后来经过面向数据编程(以及膜神犇代码)知道 ...

  8. CodeForces–830B--模拟,树状数组||线段树

    B. Cards Sorting time limit per test 1 second memory limit per test 256 megabytes input standard inp ...

  9. BZOJ_1901_&_ZJU_2112_Dynamic_Rankings_(主席树+树状数组/线段树+(Treap/Splay))

    描述 http://www.lydsy.com/JudgeOnline/problem.php?id=1901 给出一个长度为n的数列A,有m次询问,询问分两种:1.修改某一位置的值;2.求区间[l, ...

随机推荐

  1. KMP算法详解 --- 彻头彻尾理解KMP算法

    前言 之前对kmp算法虽然了解它的原理,即求出P0···Pi的最大相同前后缀长度k. 但是问题在于如何求出这个最大前后缀长度呢? 我觉得网上很多帖子都说的不是很清楚,总感觉没有把那层纸戳破, 后来翻看 ...

  2. How to Convert Subversion Repo to Git

    用了比较长时间的 SVN,但现在新的项目都采用Git.之前的项目又不得不维护,那么能不能将项目从SVN迁移到Git呢.答案是肯定的,网上的方案是 git-svn,或者更高级的封装 svn2git. 方 ...

  3. Linq查询操作之投影操作

    投影操作,乍一看不知道在说啥.那么什么是投影操作呢?其实就是Select操作,名字起的怪怪的.和Linq查询表达式中的select操作是一样的.它能够选择数据源中的元素,并指定元素的表现形式.投影操作 ...

  4. [爬虫学习笔记]基于Bloom Filter的url去重模块UrlSeen

            Url Seen用来做url去重.对于一个大的爬虫系统,它可能已经有百亿或者千亿的url,新来一个url如何能快速的判断url是否已经出现过非常关键.因为大的爬虫系统可能一秒钟就会下载 ...

  5. 那晚征服的一道js经典的面试题

    今天朋友共享了一道js中经典的面试题,需求是这样的 给定你任意一个字符串,让你写出一个算法,求算出该字符串中出现次数最多的一个字符,并将其结果输出 刚拿到这道题的第一感觉便是定义一个count计时器, ...

  6. 关于 hangfire 的权限问题

    hangfire 是一个分布式后台执行服务. 官网:http://hangfire.io/ 我看中hangfire的地方是 1:使用简单 2:多种持久化保存方案.支持sqlserver ,msmq等 ...

  7. Windows nexus 启动失败

    现象: nexus Windows系统服务安装成功,但启动失败 D:\nexus-2.10.0-02-bundle\nexus-2.10.0-02\bin>nexus.bat Usage: ne ...

  8. ASP.NET Web API 路由

    路由系统是请求消息进入ASP.NET Web API消息处理管道的第一道屏障,其根本目的是利用注册的路由表(RouteTable)对请求的URI进行解析以确定目标HttpController和Acti ...

  9. android ArrayAdapter BaseAdapter SimpleAdapter使用讲解

    不是我针对谁,我只想针对新手玩家. 不清楚Adapter作用的可以看一下http://www.cnblogs.com/zhichaobouke/p/5798672.html (括号里的内容都是我主观添 ...

  10. javascript --- 将共享属性迁移到原型中去

    当我们用一个构造函数创建对象时,其属性就会被添加到this中去.并且被添加到this中的属性实际上不会随着实体发生改变,这时,我们这种做法显得会很没有效率.例如: function her(){ th ...