内容提要

有关数据结构的例题


求逆序对数

统计每个数前面有多少比他大的数

开数组表示这个数之前0~9这些数出现了几次

动态将某个点加一,动态求前缀和

用树状数组

如果数太大了怎么办?

离散化

步骤:先把原数组排序,然后unique去重,之后按原数组lower_bound查找

Stars

由于我们是按照y的升序处理这个星星的,所以在处理的时候只需要处理x<=当前给定的x的个数就好了,用前缀和搞一搞,也是树状数组

二维偏序

一维排序

一维树状数组

Queries

直接开m个树状数组,每个树状数组中都是0/1的,每个位置a[i]表示a[i]这个数%m是否=0,是就是1,不是就是0

第i个树状数组的第j个下标表示a[i]%m是否=i

查询的时候只需要在第mod个数组查询[l,r]的前缀和就可以了

加减的操作就在原来的基础上搞一搞就行了

营业额统计

  1. set做法
  2. 线段树

我们维护0~9每个数当前的次数,某一个数前面的最大值和后面的最小值再与这个数做差,最小的就是波动值

维护一个线段树,每次求一个区间的最大值,一个区间的最小值

权值线段树,他的下标不是数组的下标,而是权值的下标

维护序列

维护两个标记

Sasha and array

考虑矩阵乘法

F为矩阵

实际上就是求[l,r]的ΣF[ai]然后乘[1 1]矩阵

区间加法其实就是对矩阵进行区间乘法

于是就变成了区间乘法,区间求和

花神游历各国

每次开根号单点修改去开,longlong范围内最多开6次就会全变成1或0

直到某个区间全部变成1或0就把他打上标记

中位数之和

每插入一个数,他的中位数之和都会发生改变

S[s1,s2,s3,s4,s0]分别表示集合中%5余1,2,3,4,0的数的和

建一棵权值线段树,以a[i]为下标,每一个节点表示在原先的大小在[l,r]中的数在长度为5的数组中长什么样子,以及大小在[l,r]中出现了多少数

大小为k的在合并时需要向后滚动k个再相加

修改:只需要单点修改

先将要处理的数字离散化。

按数字的顺序为下标建立一颗线段树。

线段树的每个节点维护如下几个值:

这一段闭区间中有几个数字

a[0..4]表示下标模5余某的数值之和

单点修改,区间查询即可完成操作。

Rmq problem

Mex表示[l,r]没有出现的最小非负整数

常在博弈论中求sg函数

离线做

扫一遍可以得到以1为左端点的mex值

每次将l右移1,更新r的值

当拿走一个数时,如果这个数只有一个,那么所有大于他的mex都会变成这个数

区间修改取min

对于所有的r,单点查询,标记下放

单次询问log(n)

只有查询没有修改

等差子序列

实质上是求是否存在三元组(i,j,k),满足i<j<k且Ak-Aj=Aj-Ai

如果一个数出现过,就让对应位置变成1,否则为0

枚举等差中项,我们看看是否对称,如果对称就意味着都在这个数之前或者之后出现,也就是说不可能以这个数作为等差中项

  1. 单点修改
  2. 比较两段区间是否相同(等于比较两个字符串是否相同)

每个节点表示这个节点的hash值,单点修改,比较hash值

qbzt day3 下午(好难)的更多相关文章

  1. QBZT Day3(zhx ak IOI)

    动态规划 DP和前几天学的东西不大一样,动态规划和数据结构相比是一个非常抽象的东西 先来看看斐波那契数列 定义是F0=0,F1=1,Fn=F(n-1)+F(n-2) 0,1,1,2,3,5,8,13, ...

  2. qbzt day6 下午 模拟赛

    我太菜了 T2 给定一张有向图,每个点有点权.试找到一条路径,使得该路径上的点权最 大值减去点权最小值最大,问这个差最大是多少.   话说这个题第一个想到的思路是tarjan缩点+拓扑排序来着... ...

  3. Day3下午解题报告

    预计分数:20+40+30=90 实际分数:40+90+60=190 再次人品爆发&&手感爆发&&智商爆发 谁能告诉我为什么T1数据这么水.. 谁能告诉我为什么T2数据 ...

  4. qbzt day5 下午

    农场主John新买了一块长方形的新牧场,这块牧场被划分成M行N列(1 ≤ M ≤ 12; 1 ≤ N ≤ 12),每一格都是一块正方形的土地.John打算在牧场上的某几格里种上美味的草,供他的奶牛们享 ...

  5. qbzt day4 下午

    有向图的强连通分量 强联通:两个点之间可以互相到达 如果某个图任意两个点都是强联通的,那么称这个图强联通 如果一个图的子图是强联通的,那么称这个图是强联通子图 一个图的极大强联通子图被称作强连通分量 ...

  6. qbzt day3 晚上 平衡树的一些思想

    pks大佬的blog 二叉查找树 任何一个节点左子树的所有元素都小于这个节点,右子树的所有元素都大于这个节点 查找一个节点:从根节点开始,比他小就向左走,比他大就向右走 平衡树:解决二叉查找树的一些痛 ...

  7. qbzt day3 上午

    内容提要 堆 lca(最近公共祖先) st表 hash 并查集 树状数组 线段树 数据结构 1.堆 Priority_queue 他滋兹:插入删除查询最大值(最小值) 分为大根堆小根堆 2.LCA 首 ...

  8. qbzt day2 下午

    内容提要 高精 矩阵 筛法 先是高精除法 注意细节 高精度开方:神奇的竖式 以小数点为分界线,每两个位砍一刀 87654.321-->08|76|54|.32|1 大概就是先对第一位开方,然后相 ...

  9. PKUWC 2019 自闭记

    PKUWC 2019 自闭记 Day -1 考前天天在隔壁的物竞教室划水(雀魂,能和吉老师一起玩的游戏都是好游戏),没有做题. Day 0 早上8:16的高铁,到广州南居然要6个小时...不知道福州和 ...

随机推荐

  1. 嘉馨学姐又双叒叕来吃包子了 QDUOJ 模拟 尺度法

    嘉馨学姐又双叒叕来吃包子了 QDUOJ 模拟 尺度法 点我进入OJ题目详情 题意 给你一串数,让你求长度最长的子串,这个字串满足里面没有重复出现的数字. 解题思路 使用一个标记数组,来标记每个数的第一 ...

  2. HDU 3466 Proud Merchants 带有限制的01背包问题

    HDU 3466 Proud Merchants 带有限制的01背包问题 题意 最近,伊萨去了一个古老的国家.在这么长的时间里,它是世界上最富有.最强大的王国.因此,即使他们的国家不再那么富有,这个国 ...

  3. osi七层模型??

    1.应用层:提供用户服务,例如处理应用程序,文件传输,数据管理      (HTTP.RTSP.FTP) 2.表示层:做数据的转换和压缩,加解密等 3.会话层:决定了进程间的连接建立,选择使用什么样的 ...

  4. CSS的优先级理解

    样式的优先级 多重样式(Multiple Styles):如果外部样式.内部样式和内联样式同时应用于同一个元素,就是使多重样式的情况. 一般情况下,优先级如下: (外部样式)External styl ...

  5. hdu 1087 最大递增子序列和

    #include <bits/stdc++.h> #define PI acos(-1.0) #define mem(a,b) memset((a),b,sizeof(a)) #defin ...

  6. visual studio中配置opencv

    第1步附加包含目录:H:\software\programming\opencv\opencv\build\include 第2步附加库目录:H:\software\programming\openc ...

  7. java并发学习--第十章 java内存模型的内存语义

    一.锁的内存语义 所为的java内存模型的内存语义指的就是在JVM中的实现原则. 锁的内存语义:锁除了让临界区互斥执行外,还可以让释放锁的线程向获取同一个锁的线程发送消息. 我们把上面这句话再整理下: ...

  8. @RequestBody、@RequestParam、@PathVariable区别与使用场景

    由于项目是前后端分离,因此后台使用的是spring boot,做成微服务,只暴露接口.接口设计风格为restful的风格,在get请求下,后台接收参数的注解为RequestBody时会报错:在post ...

  9. C++ GUI Qt4学习笔记07

    C++ GUI Qt4   qtc++scrollobject编程 事件(event)是由串口系统或者Qt自身产生的,用以响应所发生的各类事情.当用户按下或者松开键盘或者鼠标上的按键时,就可以产生一个 ...

  10. python-第三方包的安装和升级和卸载

    安装源: 豆瓣   http://pypi.douban.com/simple/ 本地安装: egg文件:  使用settools自带的安装脚本easy_install进行安装 whl文件:      ...