【BZOJ】1878: [SDOI2009]HH的项链(树状数组)

时间:2022-09-06 15:01:50

http://www.lydsy.com/JudgeOnline/problem.php?id=1878

【BZOJ】1878: [SDOI2009]HH的项链(树状数组)

我太弱了,看题解才过的。

一开始看到此题,我想了想在线做法,但之后觉得这个想法可能是错的:维护一颗splay,按输入顺序建树,将相同节点缩点,维护2个值,一个是size,为节点数量,一个是size2,为不同节点数量,然后取区间操作即可。但是后来想想,此方法应该不行,因为在掉区间的时候,,你把点缩掉了。。。。。。。。。。。。。。。。。。

写这篇文章的时候又想到一个做法。。。维护2颗splay,一颗为正常的,用来取区间,一颗为缩点的。说下做法吧,在正常的树上取了区间后,在此区间求最左边的值,用这个值放去缩点的splay上伸展到根,然后左子树的size就是答案啦~~

来说这题的做法:

首先我是用离线的,用树状数组维护前缀和。

找出每个数第一次出现的位置,记为ihead[u],并且记录每个数的相同数的下一个位置,记为inext[i]。

然后将每一个头先加入前缀后,即将所有的ihead[u]加入到前缀和中去。

接下来将所有的询问以l排序。

从左往右扫,如果在i这个询问前有inext,那么就全部加上去。。。。因为头已经在外面了,所以要将里面的加进去。。

#include <cstdio>
#include <algorithm>
using namespace std;
#define lowbit(x) (x&-x)
#define max(a,b) ((a)>(b)?(a):(b)) const int N=50005, M=200005;
int bit[N], a[N], n, m, ihead[1000005], inext[N];
struct Q {
int l, r, id, ans;
}q[M];
bool cmp1(const Q &a, const Q &b) { return a.l==b.l?a.r<b.r:a.l<b.l; }
bool cmp2(const Q &a, const Q &b) { return a.id<b.id; } inline int read() {
int ret=0; char c;
for(c=getchar(); c<'0' || c>'9'; c=getchar());
for(; c>='0' && c<='9'; c=getchar()) ret=ret*10+c-'0';
return ret;
}
inline void add(int x, const int &y) { while(x<=n) bit[x]+=y, x+=lowbit(x); }
inline int sum(int x) { int ret=0; while(x>0) ret+=bit[x], x-=lowbit(x); return ret; } int main() {
n=read();
int i, maxi=0, l=1;
for(i=1; i<=n; ++i) a[i]=read(), maxi=max(maxi, a[i]);
for(i=n; i>=0; --i) inext[i]=ihead[a[i]], ihead[a[i]]=i;
for(i=0; i<=maxi; ++i) if(ihead[i]) add(ihead[i], 1);
m=read();
for(i=1; i<=m; ++i) q[i].l=read(), q[i].r=read(), q[i].id=i;
sort(q+1, q+1+m, cmp1);
for(i=1; i<=m; ++i) {
while(l<q[i].l) {
if(inext[l]) add(inext[l], 1);
++l;
}
q[i].ans=sum(q[i].r)-sum(q[i].l-1);
}
sort(q+1, q+1+m, cmp2);
for(i=1; i<=m; ++i) printf("%d\n", q[i].ans);
return 0;
}

Description

HH有一串由各种漂亮的贝壳组成的项链。HH相信不同的贝壳会带来好运,所以每次散步 完后,他都会随意取出一段贝壳,思考它们所表达的含义。HH不断地收集新的贝壳,因此, 他的项链变得越来越长。有一天,他突然提出了一个问题:某一段贝壳中,包含了多少种不同 的贝壳?这个问题很难回答。。。因为项链实在是太长了。于是,他只好求助睿智的你,来解 决这个问题。

Input

第一行:一个整数N,表示项链的长度。 第二行:N个整数,表示依次表示项链中贝壳的编号(编号为0到1000000之间的整数)。 第三行:一个整数M,表示HH询问的个数。 接下来M行:每行两个整数,L和R(1 ≤ L ≤ R ≤ N),表示询问的区间。

Output

M行,每行一个整数,依次表示询问对应的答案。

Sample Input

6
1 2 3 4 3 5
3
1 2
3 5
2 6

Sample Output

2
2
4

HINT

对于20%的数据,N ≤ 100,M ≤ 1000;
对于40%的数据,N ≤ 3000,M ≤ 200000;
对于100%的数据,N ≤ 50000,M ≤ 200000。

Source

【BZOJ】1878: [SDOI2009]HH的项链(树状数组)的更多相关文章

  1. bzoj 1878&colon; &lbrack;SDOI2009&rsqb;HH的项链 ——树状数组&plus; 差分

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

  2. BZOJ 1878 SDOI2009 HH的项链 树状数组&sol;莫队算法

    题目大意:给定一个序列.求一个区间内有多少个不同的数 正解是树状数组 将全部区间依照左端点排序 然后每次仅仅统计左端点開始的每种颜色的第一个数即可了 用树状数组维护 我写的是莫队算法 莫队明显能搞 m ...

  3. &lbrack;SDOI2009&rsqb;HH的项链 树状数组 BZOJ 1878

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

  4. 【题解】P1972 &lbrack;SDOI2009&rsqb;HH的项链 - 树状数组

    P1972 [SDOI2009]HH的项链 声明:本博客所有题解都参照了网络资料或其他博客,仅为博主想加深理解而写,如有疑问欢迎与博主讨论✧。٩(ˊᗜˋ)و✧*。 题目描述 \(HH\) 有一串由各种 ...

  5. &lbrack;BZOJ1878&rsqb; &lbrack;SDOI2009&rsqb; HH的项链 &lpar;树状数组&rpar;

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

  6. 【bzoj1878】&lbrack;SDOI2009&rsqb;HH的项链 树状数组

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

  7. 【bzoj1878】&lbrack;SDOI2009&rsqb;HH的项链 - 树状数组 - 离线处理

    [SDOI2009]HH的项链 Time Limit: 4 Sec  Memory Limit: 64 MBSubmit: 4834  Solved: 2384[Submit][Status][Dis ...

  8. bzoj1878 &lbrack;SDOI2009&rsqb;HH的项链——树状数组

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1878 离线树状数组,巧妙的思路呢: 给每种项链记录一个最后出现的位置lst,根据项链最后出现 ...

  9. luogu P1972 &lbrack;SDOI2009&rsqb;HH的项链 &vert;树状数组 或 莫队

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

  10. 洛谷 P1972 &lbrack;SDOI2009&rsqb;HH的项链——树状数组

    先上一波题目 https://www.luogu.org/problem/P1972 这道题是询问区间内不同数的个数 明显不是正常的数据结构能够维护的 首先考虑 因为对于若干个询问的区间[l,r],如 ...

随机推荐

  1. javascript string 函数集

    JavaScript_String对象说明 string中文为"字符串"的意思,String继承自Object对象,此对象提供字符串的查找操作等函数 JavaScript字符串类型 ...

  2. 关于in与exists的效率讨论

    关于in与exists的效率讨论1).select * from A where id in (select id from B)以上查询使用了in语句,in只执行一次,他查出B表的所有id字段并缓存 ...

  3. 让java程序在后台一直执行(例如putty关闭后后台程序继续运行)

    如果在终端中执行java -jar xxx.jar&命令,当终端关闭时,xxx.jar也会同时结束运行,但是如果执行nohup java -jar xxx.jar&命令,则程序会在后台 ...

  4. &lbrack;转载&rsqb;jquery ajax&sol;post&sol;get 传参数给 mvc的action

    jquery ajax/post/get 传参数给 mvc的action 1.ActionResult Test1     2.View  Test1.aspx 3.ajax page 4.MetaO ...

  5. php 文件操作之抓取网站图片

    $str= file_get_contents("http://v.qq.com/");preg_match_all("/\<img\s+src=.*\s*\&gt ...

  6. Oracle 中的Pivoting Insert用法

    1.标准Insert --单表单行插入   语法:   INSERT INTO table [(column1,column2,...)] VALUE (value1,value2,...)      ...

  7. 通过SecureCRT下载远程Linux服务器上的文件到本地Windows

    sz  文件名[先cd到需要下载的文件的目录层] [root@is13084905-0233 bookinterface]# sz test.txt rz Starting zmodem transf ...

  8. BZOJ 4568&colon; &lbrack;Scoi2016&rsqb;幸运数字 &lbrack;线性基 倍增&rsqb;

    4568: [Scoi2016]幸运数字 题意:一颗带点权的树,求树上两点间异或值最大子集的异或值 显然要用线性基 可以用倍增的思想,维护每个点向上\(2^j\)个祖先这些点的线性基,求lca的时候合 ...

  9. JVM笔记2-Java虚拟机内存管理简介

    java虚拟机内存管理图如下图所示: 1.线程共享区,是所有的线程所共用的,线程共享区有一下几个组成: 1.方法区: 1.运行时常量池,已经被虚拟机加载的类信息(1.类的版本信息,2.字段,3.方法, ...

  10. Na&&num;239&semi;ve Media Player&comma; Part 2

    项目主页网址: https://github.com/Judylalala/en Q1:如何播放online歌曲? A1:我本来以为会为MediaElement设置一个单独的属性播放online音频. ...