bzoj千题计划181:bzoj1878: [SDOI2009]HH的项链

时间:2021-11-23 05:32:22

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

之前用莫队做的,现在用树状数组

把每种数的第一个出现位置在树状数组中+1

nxt[i] 记录i后面第一个数字和i相同的位置

对于每一个询问[l,r],输出[1,r]内数的种类-只在[1,l-1]内数的种类

[1,r]内数的种类就是记录的 每种数的第一个出现位置

只在[1,l-1]内数的种类:

对于<l的i,对应的nxt[i]在树状数组中+1,

这样query(r)-query(l-1)时,

只在[1,l-1]内的被减走

既在[1,l-1] 又在[l,r] 内的减1又加1

#include<cstdio>
#include<iostream>
#include<algorithm> using namespace std; #define N 50001
#define M 200001
#define K 1000001 int n;
int a[N];
struct node
{
int l,r;
int id;
}e[M]; bool have[K]; int nxt[N],last[K]; int c[N+]; int ans[M]; #define lowbit(x) x&-x void read(int &x)
{
x=; char c=getchar();
while(!isdigit(c)) c=getchar();
while(isdigit(c)) { x=x*+c-''; c=getchar(); }
} bool cmp(node p,node q)
{
return p.l<q.l;
} void add(int x)
{
while(x<=n+)
{
c[x]++;
x+=lowbit(x);
}
} int query(int x)
{
int sum=;
while(x)
{
sum+=c[x];
x-=lowbit(x);
}
return sum;
} int main()
{
read(n);
for(int i=;i<=n;++i)
{
read(a[i]);
if(!have[a[i]])
{
have[a[i]]=true;
add(i);
}
}
for(int i=n;i;--i)
{
if(!have[a[i]]) nxt[i]=n+;
else
{
if(!last[a[i]])
{
nxt[i]=n+;
last[a[i]]=i;
}
else
{
nxt[i]=last[a[i]];
last[a[i]]=i;
}
}
}
int m;
read(m);
for(int i=;i<=m;++i)
{
read(e[i].l);
read(e[i].r);
e[i].id=i;
}
sort(e+,e+m+,cmp);
int j=;
for(int i=;i<=m;++i)
{
while(j<e[i].l) add(nxt[j++]);
ans[e[i].id]=query(e[i].r)-query(e[i].l-);
}
for(int i=;i<=m;++i) cout<<ans[i]<<'\n';
}

1878: [SDOI2009]HH的项链

Time Limit: 4 Sec  Memory Limit: 64 MB
Submit: 5156  Solved: 2549
[Submit][Status][Discuss]

Description

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

Input

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

Output

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

Sample Input

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

Sample Output

2
2
4

bzoj千题计划181:bzoj1878: [SDOI2009]HH的项链的更多相关文章

  1. BZOJ1878 SDOI2009 HH的项链 【莫队】

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

  2. BZOJ1878&colon; &lbrack;SDOI2009&rsqb;HH的项链 &lpar;离线查询&plus;树状数组&rpar;

    1878: [SDOI2009]HH的项链 题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1878 Description: HH有一串由 ...

  3. bzoj千题计划300:bzoj4823&colon; &lbrack;Cqoi2017&rsqb;老C的方块

    http://www.lydsy.com/JudgeOnline/problem.php?id=4823 讨厌的形状就是四联通图 且左右各连一个方块 那么破坏所有满足条件的四联通就好了 按上图方式染色 ...

  4. &lbrack;bzoj1878&rsqb;&lbrack;SDOI2009&rsqb;HH的项链&lowbar;莫队

    HH 的项链 bzoj-1878 SDOI-2009 题目大意:给定一个n个数的序列.m次询问,每次询问一段区间内数的种类数. 注释:$1\le n\le 5\cdot 10^4$,$1\le m\l ...

  5. BZOJ1878 &lbrack;SDOI2009&rsqb; HH的项链 &lbrack;莫队,卡常&rsqb;

    BZOJ传送门,洛谷传送门 HH的项链 Description HH有一串由各种漂亮的贝壳组成的项链.HH相信不同的贝壳会带来好运,所以每次散步 完后,他都会随意取出一 段贝壳,思考它们所表达的含义. ...

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

    HH的项链 bzoj-1878 SDOI-2009 题目大意:给定一个n个数的序列,m次查询.查询区间数的种类个数. 注释:$1\le n \le 5\cdot 10^4$,$1\le m\le 2\ ...

  7. bzoj千题计划207:bzoj1879&colon; &lbrack;Sdoi2009&rsqb;Bill的挑战

    http://www.lydsy.com/JudgeOnline/problem.php?id=1879 f[i][j] 表示匹配了i个字符,匹配字符串的状态为j的方案数 枚举下一个字符是什么 计算加 ...

  8. bzoj千题计划288:bzoj1876&colon; &lbrack;SDOI2009&rsqb;SuperGCD

    http://www.lydsy.com/JudgeOnline/problem.php?id=1876 高精压位GCD 对于  GCD(a, b)  a>b 若 a 为奇数,b 为偶数,GCD ...

  9. bzoj千题计划287:bzoj1228&colon; &lbrack;SDOI2009&rsqb;E&amp&semi;D

    http://www.lydsy.com/JudgeOnline/problem.php?id=1228 打SG函数表,找规律: 若n是奇数m是奇数,则SG(n,m)=0 若n是偶数m是偶数,则SG( ...

随机推荐

  1. 读取SD卡文件夹下的MP3文件和播放MP3文件

    首先获取SD卡path路径下的所有的MP3文件,并将文件名和文件大小存入List数组(此代码定义在FileUtils类中): /** * 读取目录中的Mp3文件的名字和大小 */ public Lis ...

  2. QQ空间HD&lpar;6&rpar;-实现自定义的选项卡切换效果

    DJTabbarButton.m #import "DJTabbarButton.h" @implementation DJTabbarButton - (instancetype ...

  3. Linux下c开发 之 线程通信(转)

    Linux下c开发 之 线程通信(转) 1.Linux“线程” 进程与线程之间是有区别的,不过Linux内核只提供了轻量进程的支持,未实现线程模型.Linux是一种“多进程单线程”的操作系统.Linu ...

  4. Emit学习&lpar;4&rpar; - Dapper解析之数据对象映射&lpar;一&rpar;

    感觉好久没有写博客了, 这几天有点小忙, 接下来会更忙, 索性就先写一篇吧. 后面估计会有更长的一段时间不会更新博客了. 废话不多说, 先上菜. 一.示例 1. 先建类, 类的名称与读取的表名并没有什 ...

  5. Python介绍、安装、使用

    Python介绍.安装.使用 搬运工:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.Python语言介绍 说到Python语言,就不得不说一下它的创始人Guido van Rossu ...

  6. SRF之日志和异常

    日志: 日志功能采用log4net实现 log4配置文件在站点目录下的log4net.config. 调用log4写日志的代码如下: log4net.ILog logger = log4net.Log ...

  7. 关于jqueryUI里的拖拽排序

    主要参考http://jsfiddle.net/KyleMit/Geupm/2/  (这个站需要FQ才能看到效果) 其实是jqueryUI官方购物车拖拽添加例子的增强版,就是在拖拽的时候增加了排序 这 ...

  8. java多线程系列&lpar;二&rpar;

    对象变量的并发访问 前言:本系列将从零开始讲解java多线程相关的技术,内容参考于<java多线程核心技术>与<java并发编程实战>等相关资料,希望站在巨人的肩膀上,再通过我 ...

  9. LeetCode——Product of Array Except Self

    Description: Given an array of n integers where n > 1, nums, return an array output such that out ...

  10. Kotlin 第一弹:自定义 ViewGroup 实现流式标签控件

    古人学问无遗力, 少壮工夫老始成.纸上得来终觉浅, 绝知此事要躬行. – 陆游 <冬夜读书示子聿> 上周 Google I/O 大会的召开,宣布了 Kotlin 语言正式成为了官方开发语言 ...