ACM数据结构-线段树
1.维护区间最大最小值模板(以维护最小值为例)
#include<iostream>
#include<stdio.h> #define LEN 11
#define MAX 1<<30 using namespace std; int arr[LEN]={,,,,,,,,,,};
int st[LEN*]; //segment tree
int n; void init(int len){
n=;
while(n<len) n*=; //不断乘以2,知道>=len
for(int i=;i<n;i++) st[i]=MAX;
} void update(int p,int v){ //我们有n(len的二次幂扩增)个叶子作为线段元素
p+=n-; //地址重定向,变为叶子节点所在地址
st[p]=v;
while(p>){
p=(p-)/; //向上跳转到父节点
st[p]=min(st[p*+],st[p*+]); //更新父节点
}
} // 查询[a,b)的最小值,当前函数的查询是[l,r) 。当前根节点为p
int query(int a,int b,int p,int l,int r){//外部调用: query(a,b,0,0,n)
//如果[a,b)与[l,r)不相交
if(a>=r || b<=l)
return MAX;
//如果[a,b)包裹住了[l,r)
if(a<=l && b>=r)
return st[p];
//其他情况,二分进行查询
int v1=query(a,b,p*+,l,(l+r)/);
int v2=query(a,b,p*+,(l+r)/,r);
return min(v1,v2);
} int main(){
init(LEN);
int i,a,b;
for(i=;i<LEN;i++)
update(i,arr[i]);
while(){
scanf("%d%d",&a,&b);
printf("%d\n",query(a,b,,,n));
}
return ;
}
2.维护区间和的模板
数据结构:
struct node
{
int left,right;
int num;
}tree[];
建树:
void build(int left,int right,int index) //build(1,n,1);
{
he++;
tree[index].left=left;
tree[index].right=right;
if(left==right)
return ;
int mid=(right+left)/;
build(left,mid,index*);
build(mid+,right,index*+);
}
单点修改:
void my_plus(int index,int dis,int k) //将索引为p的元素增加k
{ // my_plus(1,p,k)
tree[index].num+=k;
if(tree[index].left==tree[index].right) //没有叶子节点
return ;
if(dis<=tree[index*].right)
my_plus(index*,dis,k);
if(dis>=tree[index*+].left)
my_plus(index*+,dis,k);
}
单点查询:
int search(int index,int dis) //调用方法:查找索引为p的元素:search(1,p)
{
if(tree[index].left==tree[index].right && tree[index].left==dis)
return tree[index].num;
if(dis<=tree[index*].right)
search(index*,dis);
if(dis>=tree[index*+].left)
search(index*+,dis);
}
区间修改:
void pls(int index,int l,int r,int k)
{
if(tree[index].left>=l && tree[index].right<=r)
{
tree[index].num+=k;
return ;
}
if(tree[index*].right>=l)
pls(index*,l,r,k);
if(tree[index*+].left<=r)
pls(index*+,l,r,k);
}
区间查询:
void search(int index,int l,int r)
{
//cout<<index<<" ";
if(tree[index].left>=l && tree[index].right<=r)
{
ans+=tree[index].num;
return ;
}
if(tree[index*].right>=l)
search(index*,l,r);
if(tree[index*+].left<=r)
search(index*+,l,r);
}
3.模板编写练习:
ACM数据结构-线段树的更多相关文章
- ACM/ICPC 之 数据结构-线段树+区间离散化(POJ2528)
这道题用线段树做更方便更新和查询,但是其数据范围很大,因此要将离散化和线段树结合起来,算是一道比较经典的线段树+离散化的例题. 线段树的离散化有很多方法,在这里,我先用一次结点离散化,间接将源左右端点 ...
- ACM/ICPC 之 数据结构-线段树思想(POJ2182,含O(n^2)插入式解法)
这道题在一定程度上体现了线段树的一种用法,解决的问题是:对于总计n个元素的第i个元素,已知其在[1,i]上部分序列的排名,求第i个元素在所有n个元素中的排名. 当然这道题数据比较水,所以用O(n^2) ...
- 算法手记 之 数据结构(线段树详解)(POJ 3468)
依然延续第一篇读书笔记,这一篇是基于<ACM/ICPC 算法训练教程>上关于线段树的讲解的总结和修改(这本书在线段树这里Error非常多),但是总体来说这本书关于具体算法的讲解和案例都是不 ...
- 模板 - 数据结构 - 线段树/SegmentTree
区间求加法和: 单点修改的,普通线段树. struct SegmentTree { #define ls (o<<1) #define rs (o<<1|1) static c ...
- 第二十九篇 玩转数据结构——线段树(Segment Tree)
1.. 线段树引入 线段树也称为区间树 为什么要使用线段树:对于某些问题,我们只关心区间(线段) 经典的线段树问题:区间染色,有一面长度为n的墙,每次选择一段墙进行染色(染色允许覆盖),问 ...
- hiho1079 - 数据结构 线段树(入门题,离散化)
题目链接 描述 小Hi和小Ho在回国之后,重新过起了朝7晚5的学生生活,当然了,他们还是在一直学习着各种算法~ 这天小Hi和小Ho所在的学校举办社团文化节,各大社团都在宣传栏上贴起了海报,但是贴来贴去 ...
- 数据结构--线段树--lazy延迟操作
A Simple Problem with Integers Time Limit: 5000MS Memory Limit: 131072K Total Submissions: 53749 ...
- 数据结构(线段树):BZOJ 3126: [Usaco2013 Open]Photo
3126: [Usaco2013 Open]Photo Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 222 Solved: 116 Descrip ...
- 数据结构(线段树):HDU 5649 DZY Loves Sorting
DZY Loves Sorting Time Limit: 12000/6000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Oth ...
随机推荐
- DBA职业发展之路:去“IOE”等挑战之下,DBA将何去何从?
DBA职业发展之路:去“IOE”等挑战之下,DBA将何去何从? 摘要:随着近些年来,开源.自动化.云化的兴起,DBA职业也正悄然发生一些变化.面对一系列新的挑战,DBA将如何进行职业发展?本文将给出一 ...
- .NET / C# HTTP中的GET和PSOT
需要引入using System.IO;using System.Net; public string GETs(string URL) { //创建httpWebRequest对象 HttpWebR ...
- “分而治之”,一种AI和动画系统的架构
译者注:随着国内游戏研发水平的不断提高,对画面品质的不断提升,同时大量手游使用Unity和Unreal 4等成熟的工具开发,动作状态机已经不是什么陌生的概念了.我们在项目开发时也大量使用了动作状态机. ...
- C# LINQ干掉for循环
public void OldSum() { ; ; i < ; i++) { sum0 += i; } Assert.AreEqual(, sum0); } public void NewSu ...
- Matlab中介者模式
中介者模式(Mediator Pattern)是用来降低多个对象和类之间的通信复杂性.这种模式提供了一个中介类,该类通常处理不同类之间的通信,并支持松耦合,使代码易于维护.想象一个乱糟糟的开发小组的工 ...
- 使用node+vue实现简单的WebSocket聊天功能
最近学习了一下websocket的即时通信,感觉非常的强大,这里我用node启动了一个服务进行websocket链接,然后再vue的view里面进行了链接,进行通信,废话不多说,直接上代码吧, 首先, ...
- 2.JavaScript中的原型规则以及原型设计模式
原型规则 原型规则 所有的引用类型(数组.对象.函数),都具有对象特征,即可自由扩展属性: 所有的引用类型,都有一个_proto_ 属性(隐式原型),属性值是一个普通对象: 所有函数,都具有一个pro ...
- 编写可维护的JavaScript-随笔(六)
避免空比较 If(item !== null){ item.sort(); Item.forEach(function(item){ //执行代码 } } } 以上判断中item期待的是数组类型的,但 ...
- Java 之 Scanner 类
一.Scanner 类 Scanner 是一个可以解析基本类型和字符串的简单文本扫描器. Demo: Scanner sc = new Scanner(System.in); int i = sc.n ...
- selenium.获取浏览器大小、设置浏览器位置、最大化浏览器
此篇博客学习控制浏览器的api,分别有: get_window_size() 获取浏览器大小 set_window_size() 设置浏览器位置 get_window_position() 获取浏览器 ...