数据结构--树状数组&&线段树--基本操作
随笔目的:方便以后对树状数组(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)
树状数组(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 ;
}
数据结构--树状数组&&线段树--基本操作的更多相关文章
- 洛谷P2414 阿狸的打字机 [NOI2011] AC自动机+树状数组/线段树
正解:AC自动机+树状数组/线段树 解题报告: 传送门! 这道题,首先想到暴力思路还是不难的,首先看到y有那么多个,菜鸡如我还不怎么会可持久化之类的,那就直接排个序什么的然后按顺序做就好,这样听说有7 ...
- 树状数组 && 线段树应用 -- 求逆序数
参考:算法学习(二)——树状数组求逆序数 .线段树或树状数组求逆序数(附例题) 应用树状数组 || 线段树求逆序数是一种很巧妙的技巧,这个技巧的关键在于如何把原来单纯的求区间和操作转换为 求小于等于a ...
- hdu1394(枚举/树状数组/线段树单点更新&区间求和)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1394 题意:给出一个循环数组,求其逆序对最少为多少: 思路:对于逆序对: 交换两个相邻数,逆序数 +1 ...
- hdu 1166:敌兵布阵(树状数组 / 线段树,入门练习题)
敌兵布阵 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
- hdu 5147 Sequence II【树状数组/线段树】
Sequence IITime Limit: 5000/2500 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Problem ...
- 「CodePlus 2017 11 月赛」Yazid 的新生舞会(树状数组/线段树)
学习了新姿势..(一直看不懂大爷的代码卡了好久T T 首先数字范围那么小可以考虑枚举众数来计算答案,设当前枚举到$x$,$s_i$为前$i$个数中$x$的出现次数,则满足$2*s_r-r > 2 ...
- 【洛谷4396/BZOJ3236】[AHOI2013]作业(莫队+分块/树状数组/线段树)
题目: 洛谷4396 BZOJ3236(权限) 这题似乎BZOJ上数据强一些? 分析: 这题真的是--一言难尽 发现题面里没说权值的范围,怕出锅就写了离散化.后来经过面向数据编程(以及膜神犇代码)知道 ...
- CodeForces–830B--模拟,树状数组||线段树
B. Cards Sorting time limit per test 1 second memory limit per test 256 megabytes input standard inp ...
- BZOJ_1901_&_ZJU_2112_Dynamic_Rankings_(主席树+树状数组/线段树+(Treap/Splay))
描述 http://www.lydsy.com/JudgeOnline/problem.php?id=1901 给出一个长度为n的数列A,有m次询问,询问分两种:1.修改某一位置的值;2.求区间[l, ...
随机推荐
- 2015年百度之星初赛(1) --- C 序列变换
序列变换 Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submis ...
- Unity实现滑页效果(UGUI)
简介 项目需要...直接展示效果吧: 原理 使用UGUI提供的ScrollRect和ScrollBar组件实现基本滑动以及自己控制每次移动一页来达到滑页的效果. 实现过程 1.创建两个panel,上面 ...
- 不可或缺 Windows Native (1) - C 语言: hello c
[源码下载] 不可或缺 Windows Native (1) - C 语言: hello c 作者:webabcd 介绍不可或缺 Windows Native 之 C 语言 在 Windows Sto ...
- mybatis中自建的类型别名
在使用mybatis过程中经常用到类型别名,除了我们自己新建的别名外,mybatis还自带了很多类型别名和java中的类型的映射,下面先看一个自建的别名的配置 <typeAliases> ...
- CentOS6.5 安装Zookeeper集群
1.下载解压 2.配置环境变量:vi ~/.bashrc 或者 vi /etc/profile [hadoopuser@Linux01 ~]$ vi ~/.bashrc # zookeeper ...
- 【GOF23设计模式】外观模式
来源:http://www.bjsxt.com/ 一.[GOF23设计模式]_外观模式.公司注册流程.迪米特法则 package com.test.facade; public interface 工 ...
- python基础之正则表达式。
简介 就其本质而言,正则表达式是内嵌在python内,由re模块实现,小型的专业化语言,最后由c写的匹配引擎执行.正则表达式(regular expression)描述了一种字符串匹配的模式,可以用来 ...
- log4net学习笔记
一直想找一个好用的日子类,今天偶然的机会看到了log4net这个类库,过来学习一下. log4net是.NET框架下的一个日子类库,官网是http://logging.apache.org/log4n ...
- Win10的分辨率问题
个人觉得win10扁平化的界面给人全新的感觉,但安装后,发现分辨率只有1280x720.1152x864.1024x768(推荐).800x600,不管调整哪一个,都觉得分辨率还是有问题,看起来字体. ...
- Effective Java 阅读笔记——枚举和注解
30:用enum代替int常量 当需要一组固定常量的时候,应该使用enum代替int常量,除了对于手机登资源有限的设备应该酌情考虑enum的性能弱势之外. 31:用实例域代替序数 应该给enum添加i ...