[模板] 树状数组 (C++ class)
闲来无事(其实是打了两三道树状数组题),写了个树状数组模板……
/*
Author: hotwords
*/ template<typename tp>
class BinTree {
private:
int n;tp *a;
public:
inline int lowbit(int x)const{return x&-x;}
int size()const{return n;}
void empty() {
if(a) delete []a;
n=;a=;
}
void clear() {
for(int i=;i<=n;++i) a[i]=;
}
void init(int w) {
empty();
n=w;
if(n) {
a=new tp[n+];
clear();
}
}
void add(int x,tp y) {
for(;x<=n;x+=lowbit(x)) a[x]+=y;
}
tp query(int x) const {
tp ans=;
for(;x;x-=lowbit(x)) ans+=a[x];
return ans;
}
tp query(int l,int r) const {
return query(r)-query(l-);
}
BinTree(){n=;a=;}
~BinTree(){empty();}
};
[模板] 树状数组
[模板] 树状数组 (C++ class)的更多相关文章
- HDU 1166 线段树模板&树状数组模板
		HDU1166 上好的线段树模板&&树状数组模板 自己写的第一棵线段树&第一棵树状数组 莫名的兴奋 线段树: #include <cstdio> using nam ... 
- 【洛谷 p3374】模板-树状数组 1(数据结构)
		题目:已知一个数列,你需要进行下面两种操作:1.将某一个数加上x:2.求出某区间每一个数的和. 解法:树状数组求前缀和. #include<cstdio> #include<cstd ... 
- 【洛谷 p3368】模板-树状数组 2(数据结构)
		题目:已知一个数列,你需要进行下面两种操作:1.将某区间每一个数数加上x:2.求出某一个数的和. 解法:树状数组+前缀和优化.数组中每位存和前一位的数的差,这样区间修改只用改两位,单点询问就是求前缀和 ... 
- POJ2299逆序对模板(树状数组)
		题目:http://poj.org/problem?id=2299 只能相邻两个交换,所以交换一次只会减少一个逆序对.所以交换次数就是逆序对数. ps:原来树状数组还可以记录后边lowbit位的部分和 ... 
- 洛谷.3374.[模板]树状数组1(CDQ分治)
		题目链接 简易CDQ分治教程 //每个操作分解为一个有序数对(t,p),即(时间,操作位置),时间默认有序,用CDQ分治处理第二维 //对于位置相同的操作 修改优先于查询 //时间是默认有序的 所以可 ... 
- 【poj 3167】Cow Patterns(字符串--KMP匹配+数据结构--树状数组)
		题意:给2个数字序列 a 和 b ,问按从小到达排序后,a中的哪些子串与b的名次匹配. a 的长度 N≤100,000,b的长度 M≤25,000,数字的大小 K≤25. 解法:[思考]1.X 暴力. ... 
- 洛谷P3368 【模板】树状数组 2
		P3368 [模板]树状数组 2 102通过 206提交 题目提供者HansBug 标签 难度普及/提高- 提交 讨论 题解 最新讨论 暂时没有讨论 题目描述 如题,已知一个数列,你需要进行下面两 ... 
- 洛谷P3374 【模板】树状数组 1
		P3374 [模板]树状数组 1 140通过 232提交 题目提供者HansBug 标签 难度普及/提高- 提交 讨论 题解 最新讨论 题目描述有误 题目描述 如题,已知一个数列,你需要进行下面两 ... 
- poj 3486 A Simple Problem with Integers(树状数组第三种模板改段求段)
		/* 树状数组第三种模板(改段求段)不解释! 不明白的点这里:here! */ #include<iostream> #include<cstring> #include< ... 
随机推荐
- react state成员
			组件中包括state,props与render成员函数. react中,主要通过定义state,根据不同state渲染对应用户界面. 过程调用了成员函数setState(data,callback). ... 
- QTL定位相关
			1.原理 https://www.sohu.com/a/211301179_278730 较为详细 
- springboot 返回json字符串格式化问题
			在idea中yml文件中添加以下注解就可以格式化json字符串效果 spring: jackson: serialization: indent-output: true 原返回json格式为: {& ... 
- 5种网络IO模型
			5种网络IO模型(有图,很清楚) 同步(synchronous) IO和异步(asynchronous) IO,阻塞(blocking) IO和非阻塞(non-blocking)IO分别是什么,到 ... 
- 二十八、linux下权限管理chmod
			(1)查看权限 终端下需要查看文件或文件夹的权限时,可以使用ll查看当前目录的各文件权限. 如图,r代表读取权限,w代表写入权限,x代表执行权限:-代表普通文件,d代表文件夹.使用命令chmod可以修 ... 
- excel 批量上传图片
			1.在excel中 输入公式 ="<table><img src=""D:\素材\"&A2&".jpeg&quo ... 
- js点击加载更多可以增加几条数据的显示
			<div class="list"> <div class="one"> <div class="img" ... 
- x变成y的最少操作次数(层次遍历)
			输入x,y,x为源数字,y为目标值.输出x变成y的最少操作次数. x每次可以执行三种操作:-1 . +1 . x2: 如 x=5,y=8:5-1=4,4x2=8;所以输出结果为2(次操作). 可以发现 ... 
- CRM创建BP(END USER)
			FUNCTION ZCRM_BP_CRT. *"---------------------------------------------------------------------- ... 
- DOM 操作成本究竟有多高,HTML、CSS构建过程 ,从什么方向出发避免重绘重排)
			前言: 2019年!我准备好了 正文:从我接触前端到现在,一直听到的一句话:操作DOM的成本很高,不要轻易去操作DOM.尤其是React.vue等MV*框架的出现,数据驱动视图的模式越发深入人心,jQ ... 
