浅谈线段树

本文介绍了线段树的基础概念、原理以及区间查询和修改的操作。线段树能以O(log2N)的时间复杂度进行区间修改和统计,通过懒标记优化能更高效地处理区间数据。并给出了两道线段树相关的编程题,帮助理解线段树在实际问题中的应用。
摘要由CSDN通过智能技术生成

基础概念:

线段树是一种二叉树。
假设有编号从1到N的N个点,用 [ L , R ] [L,R] [L,R]表示区间中的点。
线段树可以对编号连续的点进行修改或者统计操作,修改和统计的复杂度都是 O ( l o g 2 N ) O(log_2N) O(log2N)

原理:

[ 1 , N ] [1,N] [1,N]分解成若干个区间 (数量不超过 4 × N 4×N 4×N), 然后,
将每个区间 [ L , R ] [L,R] [L,R]再次分解为子区间,
通过对这些子区间的修改或者统计,
来实现快速对 [ L , R ] [L,R] [L,R]进行修改或者统计。

总的来说,线段树就是将区间 [ 1 , N ] [1,N] [1,N]分成若干个子区间 [ L , M ] 和 [ M + 1 , R ] [L,M]和[M + 1, R] [L,M][M+1,R]
定义一个结构体 t r e e [ 4 ∗ M a x x ] tree[4 * Maxx] tree[4Maxx]

struct t {
   
	int l; //左子树编号
	int r; //右子树编号
	int value; //权值
	int add; //懒标记
}tree[4 * Maxx];

如图:(上图是区间权值,下图是节点编号

val=4
val=2
val=1
val=4
val=2
val=1
val=2
val=1
val=1
val=1
val=2
val=1
val=1
val=1
1 - 8 val=8
1 - 4
1 - 2
1 - 1
5 - 8
5 - 6
5 - 5
3 - 4
3 - 3
2 - 2
4 - 4
7 - 8
7 - 7
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值