题意

询问区间有多少不同的数。

题解

和Luogu 1903一样,这道题也是用pre数组来求区间不同数的个数,这里pre[i]表示a[i]上一次出现的位置 +1,询问相当于查询区间内有多少pre小于等于左端点。

#include <cstdio>
#include <cstring>
#include <algorithm>
#include <set>
using namespace std;
typedef long long ll;
#define space putchar(' ')
#define enter putchar('\n')
template <class T>
void read(T &x){char c;bool op = 0;while(c = getchar(), c < '0' || c > '9')if(c == '-') op = 1;x = c - '0';while(c = getchar(), c >= '0' && c <= '9')x = x * 10 + c - '0';if(op) x = -x;
}
template <class T>
void write(T x){if(x < 0) x = -x, putchar('-');if(x >= 10) write(x / 10);putchar('0' + x % 10);
}
const int N = 50005;
int n, m, l, r, ans, a[N], last[1000005], pre[N];
int idx, ls[N*50], rs[N*50], data[N*50], root[N];
void build(int &k, int l, int r){k = ++idx;if(l == r) return;int mid = (l + r) >> 1;build(ls[k], l, mid);build(rs[k], mid + 1, r);
}
void change(int old, int &k, int l, int r, int p, int x){k = ++idx;ls[k] = ls[old], rs[k] = rs[old], data[k] = data[old];if(l == r) return (void)(data[k] += x);int mid = (l + r) >> 1;if(p <= mid) change(ls[old], ls[k], l, mid, p, x);else change(rs[old], rs[k], mid + 1, r, p, x);data[k] = data[ls[k]] + data[rs[k]];
}
int query(int old, int k, int l, int r, int ql, int qr){if(ql <= l && qr >= r) return data[k] - data[old];int mid = (l + r) >> 1, ret = 0;if(ql <= mid) ret += query(ls[old], ls[k], l, mid, ql, qr);if(qr > mid) ret += query(rs[old], rs[k], mid + 1, r, ql, qr);return ret;
}
int main(){read(n);build(root[0], 1, n);for(int i = 1; i <= n; i++){read(a[i]);pre[i] = last[a[i]] + 1;last[a[i]] = i;change(root[i - 1], root[i], 1, n, pre[i], 1);}read(m);while(m--){read(l), read(r);write(query(root[l - 1], root[r], 1, n, 1, l)), enter;}return 0;
}

转载于:https://www.cnblogs.com/RabbitHu/p/BZOJ1878.html

BZOJ 1878 HH的项链 | 主席树相关推荐

  1. BZOJ 1878 hh的项链(简单莫队)

    Description HH有一串由各种漂亮的贝壳组成的项链.HH相信不同的贝壳会带来好运,所以每次散步 完后,他都会随意取出一 段贝壳,思考它们所表达的含义.HH不断地收集新的贝壳,因此他的项链变得 ...

  2. BZOJ 1878 HH的项链

    莫队 还是一道模板..不过洛谷数据加强了,必须要奇偶性排序+吸氧才能过,BZOJ可以直接过的- #include <bits/stdc++.h> #define INF 0x3f3f3f3 ...

  3. BZOJ 3524: [Poi2014]Couriers【主席树】

    3524: [Poi2014]Couriers [题目描述] 传送门 [题解] 主席树的裸题,要找出现次数大于一半的,那么他肯定出现在当前的左子树或右子树中,就这样查找就可以了. 代码如下 #incl ...

  4. [BZOJ 4571][Scoi2016]美味(主席树)

    Description 一家餐厅有 n 道菜,编号 1...n ,大家对第 i 道菜的评价值为 ai(1≤i≤n).有 m 位顾客,第 i 位顾客的期 望值为 bi,而他的偏好值为 xi .因此,第 ...

  5. Bzoj 1901: Zju2112 Dynamic Rankings 主席树,可持久,树状数组,离散化

    1901: Zju2112 Dynamic Rankings Time Limit: 10 Sec  Memory Limit: 128 MB Submit: 6321  Solved: 2628 [ ...

  6. Bzoj 3932: [CQOI2015]任务查询系统(主席树)

    3932: [CQOI2015]任务查询系统 Time Limit: 20 Sec Memory Limit: 512 MB Description 最近实验室正在为其管理的超级计算机编制一套任务管理 ...

  7. bzoj 4408: [FJOI2016]神秘数 主席树

    先看一下对于给定的一段如何暴力求最大值,首先将这一段排序,然后如果存在某一个数,这个数比它前面的数的前缀和至少大2,那么答案就是它前面那个数的前缀和+1. 那么假设现在处理了前面较小的一些数之后的答案 ...

  8. BZOJ3473:字符串(后缀数组,主席树,二分,ST表)

    Description 给定n个字符串,询问每个字符串有多少子串(不包括空串)是所有n个字符串中至少k个字符串的子串? Input 第一行两个整数n,k. 接下来n行每行一个字符串. Output 一 ...

  9. NOI数据结构:主席树

    主席树详解 主席树详解_西红柿爱炒番茄-CSDN博客 最详细的主席树(不修改,待修改) BZOJ 1901 最详细的主席树(不修改,待修改) BZOJ 1901_Bartholomew_的博客-CSD ...

最新文章

  1. Redux 入门教程(三):React-Redux 的用法
  2. 浙江理工大学电信宽带校园网访问添加路由表命令(Windows和Liunx)
  3. 清默网络linux班,linux笔记(26)grep
  4. Android缩放比例公式,android开发 缩放到指定比例的尺寸
  5. springboot 技术图谱_java后台(Springboot)开发知识图谱高频技术汇总-学习路线...
  6. 游戏主播这个行为终于有人治了!腾讯下“禁令”
  7. PID算法C语言实现
  8. Node.js meitulu图片批量下载爬虫1.03版
  9. 工控安全入门常用逻辑编程
  10. 串口WriteFile 句柄无效 的解决
  11. C# 实现俄罗斯方块
  12. 稿定设计怎么去除水印?
  13. 终于有一篇能让小白更容易理解GC算法的文章了
  14. 【爬虫+多线程+MySQL】网抑云音乐评论爬取
  15. 如何自己编译wireless tool
  16. MQ-2烟雾传感器启动
  17. c# 调用系统默认图片浏览器打开图片
  18. abaqus对应python版本_abaqus with python 小问题罗列(持续更新)
  19. lazarus python_lazarus中文版
  20. 2016年关于情感问题的一点见解-感想篇|寻找C站宝藏

热门文章

  1. document.compatMode的CSS1compat
  2. [Github项目推荐] 机器学习 Python 知识点速查表
  3. nginx html解析插件,nginx配置信息的解析流程
  4. bin文件怎么转换成文本文档_Python脚本4:根据txt文本,批量创建文件夹
  5. (Oracle)关于blob转到目标库报ORA-01461: 仅能绑定要插入 LONG 列的 LONG 值错误解决方案...
  6. 配置HAProxy支持https协议
  7. solr 配置中文分词器
  8. myeclipse上进行tomcat远程调试
  9. 最全面的Android Studio使用教程【申明:来源于网络】
  10. 展示29个美丽的iPhone壁纸