qbxt Day 2 afternoon

——2020.1.18 济南 主讲:李佳实

目录一览

1.线段树
2.二叉搜索树(略过)
3.树状数组

总知识点:基础数据结构(本人初学感觉好难)

一、线段树

1.描述:线段树是一种分治的思想,用树形结构把一个大区间划分成小区间,它同时又是一棵二叉树。
2.概念名词定义:
区间(又称线段):线段树上的每一个节点对应于一个区间[a,b]。(a,b为整数)
特殊说明:对于叶子节点,其对应的区间长度为1。

For Example:
(1)区间[1,10]对应的线段树

(2)区间[1,9]对应的线段树

3.性质:对于每一个非叶结点所表示的结点[a,b],其左儿子表示的区间为[a,(a+b)/2],右儿子表示的区间为[(a+b)/2+1,b](除法去尾取整)
4.基本操作:
(1)线段树的存储:类似于堆
对于一棵线段树,它的根节点下标为1。
其下标为i的节点,它的左儿子下标为2i,右儿子下标为2i+1。
(2)线段树核心操作:区间分解
定义:若线段树根节点对应区间为[a,b],给定区间c,d,找出一些节点,使这些节点对应的区间互相不重叠,且加起来正好是[c,d],这样的操作过程即区间分解。

代码核心思想:二分

操作步骤:(递归分解)
1.从根节点出发,开始区间分解
2.遇到节点[x,y]时,如果要分解的区间就是[x,y],即为找到一个终止节点,Break。
3.否则,(二分思想)定义mid,取mid=(x+y)/2。
4.看我们要分解的区间与[x,mid]和[mid+1,y]和哪个有交集,就进入区间进行进一步的递归分解。(有可能与左右两个区间都有交集,需要同时分解)
注:区间分解的时间复杂度和分解完以后的区间个数均为O(logn)。

For Example:区间[1,9]的线段树上,分解区间[2,8].

代码实现:

inline void spilt(int k,int l,int r,int z,int y){
        //k为当前节点的编号
    //l,r为线段树的总区间。z,y为要分解的目标区间[z,y]
    if(l==z&&r==y) return;  //找到了一个分解的区间
    int mid=(l+r)/2;
    if(y<=mid) spilt(k*2,l,mid,z,y);    //在左儿子的区间里,分解左儿子的区间
    else if(z>mid) spilt(k*2+1,mid+1,r,z,y);    //在右儿子的区间里,分解右儿子的区间
    else{   //两个区间都有交集
        spilt(k*2,l,mid,z,mid); //目标区间在左儿子里的部分
        spilt(k*2+1,mid+1,r,mid+1,y);   //目标区间在右儿子里的部分
    }
}
//例:(上图)spilt(1,1,9,2,8) 

二、二叉搜索树:本内容主要为了以后学习平衡树Tree,暂且略过。。。。。。(勿喷)

三、树状数组:(心碎的回忆)

1.定义:
For Example:
以56为例:56->111000
K=3
56-2^3+1=(110001)(二进制)=49
C[56]=a[49]+..+a[56]
a[1...56]=C[56]+C[48]+C[32]

2.结构

注:A是原数组、C是树状数组。

3.执行操作:单点修改、区间查询
4.(玄学操作)lowbit

2^k=lowbit(x)=x and (x xor(x-1))

For Example:
假设:
x = 0...1...0...10......0(第二个1后k个0)
x = 0...1...0...01......1(第三个0后k个1)

x xor(x-1)=0...0...0...11......1(第一个1后k+1个1)
5.查询操作
代码:

int query(int x)    //求a[1...x]的和
{
    int res=0;
    for(int i=x;i>0;i-=lowbit(i)) res+=C[i];
    return res;
}

6.修改操作
代码:
```c++
void add(int x,int delta) //将a[x]添加delta
{
for(int i=x;i<=n;i+=lowbit(i)) C[i]+=delta;
}

---------------------------------------------THE END---------------------------------------------------

清北学堂—2020.1提高储备营—Day 2 afternoon(线段树、树状数组)的更多相关文章

  1. 清北学堂—2020.1提高储备营—Day 4 afternoon(动态规划初步(一))

    qbxt Day 4 afternoon --2020.1.20 济南 主讲:顾霆枫 目录一览 1.动态规划初步 2.记忆化搜索 3.递推式动态规划 4.记忆话搜索与递推式动态规划的转化 5.状态转移 ...

  2. 清北学堂—2020.1提高储备营—Day 1 afternoon(二分、分治、贪心)

    qbxt Day 1 afternoon --2020.1.17 济南 主讲:李佳实 目录一览 1.二分法 2.分治 3.贪心 总知识点:基础算法 一.二分法 (1)算法分析:二分法是一种暴力枚举的优 ...

  3. 清北学堂—2020.1提高储备营—Day 4 morning(数论)

    qbxt Day 4 morning --2020.1.20 济南 主讲:李奥 目录一览 1.一些符号与基本知识 2.拓展欧几里得,逆元与欧拉定理 3.线性筛法与积性函数(非重点) 总知识点:数论 一 ...

  4. 清北学堂—2020.1提高储备营—Day 3(图论初步(二))

    qbxt Day 3 --2020.1.19 济南 主讲:李奥 目录一览 1.图论(kruskal算法,最短路径算法,拓扑排序) 总知识点:图论 一.kruskal算法 1.目的:求图的最小生成树 2 ...

  5. 清北学堂—2020.1提高储备营—Day 3(图论初步(一))

    qbxt Day 3 --2020.1.19 济南 主讲:李奥 目录一览 1.图论(图.图的存储方式.最小生成树的定义) 总知识点:图论 前言:众所周知,图论是一个非常重要的部分,而这次集训也可以算从 ...

  6. 清北学堂—2020.1提高储备营—Day 1 morning(模拟、枚举、搜索)

    qbxt Day 1 morning --2020.1.17 济南 主讲:李佳实 目录一览 1.模拟和枚举 2.基础搜索算法(DFS.BFS.记忆化搜索)以及进阶搜索算法(纯靠自学) 总知识点:基础算 ...

  7. 清北学堂—2020.1提高储备营—Day 2 morning(并查集、堆)

    qbxt Day 2 morning --2020.1.18 济南 主讲:李佳实 目录一览 1.并查集 2.堆 总知识点:基础数据结构 一.并查集 1.描述:并查集是一类十分常用的数据类型,它有着十分 ...

  8. 清北学堂—2020.3NOIP数学精讲营—Day 1 morning 重点笔记

    qbxt Day 1 morning 重点笔记 --2020.3.8 济南 主讲:钟皓曦 1 正数%负数==正数 负数%正数==负数 负数%负数==负数 a%b的答案的符号取决于a的符号. 2 快速幂 ...

  9. 清北学堂 2020 国庆J2考前综合强化 Day7

    目录 1. 题目 T1 魔力石 题目描述 Sol T2 和 题目描述 Sol T3 数对 题目描述 Sol T4 海豹王国 题目描述 Sol 考场策略 1. 题目 T1 魔力石 题目描述 题目描述 小 ...

随机推荐

  1. 压力测试---Jemeter的使用

    一.线程组配置 线程组相当于有多个用户,同时去执行相同的一批次任务.每个线程之间都是隔离的,互不影响的.一个线程的执行过程中,操作的变量,不会影响其他线程的变量值. Delay Thread crea ...

  2. Iptables和Firewall-selinux

    一.Iptables防火墙 ---------- **三表五链:**三表: filter过滤表 nat转换表 mangle表五链: PREROUTING--->在进行路由选择前处理数据包 INP ...

  3. apace访问403错误的解决方法汇总

    作为一个努力学习的实习生,遇到问题还是靠记录才能更好的学习. 首先附上故障图 翻译过来就是啥呢? 于是天真的我去百度了一下大神们的解决方法,目录没权限嘛,来个777就完事了.一开始还觉得挺合乎情理的, ...

  4. PAT基础编程练习

    7-1 厘米换算英尺英寸 (15 分)   如果已知英制长度的英尺foot和英寸inch的值,那么对应的米是(.现在,如果用户输入的是厘米数,那么对应英制长度的英尺和英寸是多少呢?别忘了1英尺等于12 ...

  5. [Python源码剖析]字符缓冲池intern机制

    static PyStringObject *characters[UCHAR_MAX + 1]; ... /* This dictionary holds all interned strings. ...

  6. SpringBoot之ApplicationRunner接口和@Order注解

    我们在开发中可能会有这样的情景.需要在容器启动的时候执行一些内容.比如读取配置文件,数据库连接之类的.SpringBoot给我们提供了ApplicationRunner接口来帮助我们实现这种需求.该接 ...

  7. MySQL性能优化---索引

    一.什么是索引 索引用来快速地寻找那些具有特定值的记录,所有MySQL索引都以B-树的形式保存.如果没有索引,执行查询时MySQL必须从第一个记录开始扫描整个表的所有记录,直至找到符合要求的记录.表里 ...

  8. .NET Core之单元测试(二):使用内存数据库处理单元测试中的数据库依赖

    目录 定义一个待测试API 测试用例 为减少篇幅,隐藏了SampleEntity和SqliteDbContext 定义一个待测试API 如下,我们定义了一个名为Sample的API,其中有一个外部依赖 ...

  9. 《Head first设计模式》之迭代器模式

    迭代器模式提供一种方法顺序访问一个聚合对象中的各个元素,而又不暴露其内部的表示. 爆炸性新闻:对象村餐厅和对象村煎饼屋合并了! 真是个好消息!现在我们可以在同一个地方,享用煎饼屋美味的煎饼早餐,和好吃 ...

  10. File、FileStream、StreamWriter、StringWriter文件使用总结

    一.File 1.File为静态类 File类,是一个静态类,支持对文件的基本操作,包括创建,拷贝,移动,删除和打开一个文件.File类方法的参量很多时候都是路径path.主要提供有关文件的各种操作, ...