洛谷P1972 HH的项链
分析:
题目描述不说了,大意是,求一段区间内不同元素的种数。
看到区间,我们大概先想到的是暴力(然后炸掉)、线段树、树状数组、分块。
下面给出的是一种树状数组的想法。
首先,对于每一段区间里的数,如果出现重复的元素,我们只需要看最后一个就好了。所以,我们可以对所有需要查询区间的右端点进行从小到大的排序,从左往右枚举右端点维护一个从左向右的树状数组,表示一段区间的种类数。
听不懂的话我们举个栗子例子。
我们假设现在有一个序列:
now为现在的右端点;
insert(i , j)表示在第i 个位置出现了j个位重复的数,就需要我们在我们维护的树状数组序列中+j。
1 ,2 ,1 ,3
当now = 1时,insert(1 , 1),树状数组对应的序列就变成了1,0,0,0
当now = 2,insert(2,1),序列变成了1,1,0,0
当now = 3时,我们发现a[3]=1,而1之前已经出现过了,所以最后一次出现的地方(a[1])减1,即insert(1,−1),a[3]这个地方加1,即insert(3,1),序列变成了0,1,1,0
当now = 4时,insert(4 , 1),序列变成0,1,1,1
这样的话,我们枚举ii的时候处理一下就OK了.
最后whilewhile输出sum[ ](类似前缀和的一个数组如果查询区间[3~5],就变成sum[5]−sum[2])。
你会发现代码中还有一个last[ ],last[i]根据我的解释应该很好懂吧,表示的就是ii这个元素最后出现的位置。。
好了,代码奉上。。
#include <iostream>
#include <cstring>
#include <cstdio>
#include <algorithm>
using namespace std;
const int maxn = ; inline int read(){
char ch = getchar();
int f = ,x = ;
while(ch > '' || ch < ''){if(ch == '-')f = -;ch = getchar();}
while(ch >= '' && ch <= ''){x = (x << ) + (x << ) + ch - '';ch = getchar();}
return x * f;
} int n,a[maxn],m;
struct Edge{
int L,R,val;
}e[maxn << ];
int last[maxn],sum[maxn],ans[maxn];
int tmp; bool cmp(Edge a,Edge b){return a.R < b.R;} int lowbit(int x){return x & (-x);} void insert(int x,int v){
for(int i=x;i<=n;i+=lowbit(i))
sum[i] += v;
} int query(int x){
int s = ;
for(int i=x;i;i-=lowbit(i))
s += sum[i];
return s;
} int main(){
n = read();
for(int i=;i<=n;i++)
a[i] = read();
m = read();
for(int i=;i<=m;i++){
e[i].L = read();
e[i].R = read();
e[i].val = i;
}
sort(e + , e + + m , cmp);
int now = ;
for(int i=;i<=n;i++){
insert(i , );
if(last[a[i]]) insert(last[a[i]] , -);
last[a[i]] = i;
tmp = query(i);
while(e[now].R == i && now <= m){
ans[e[now].val] = tmp - query(e[now].L - );
now++;
}
}
for(int i=;i<=m;i++)
printf("%d\n",ans[i]);
return ;
}
洛谷P1972 HH的项链的更多相关文章
- [洛谷 P1972] HH的项链(SDOI2009)
P1972 [SDOI2009]HH的项链 题目描述 HH 有一串由各种漂亮的贝壳组成的项链.HH 相信不同的贝壳会带来好运,所以每次散步完后,他都会随意取出一段贝壳,思考它们所表达的含义.HH 不断 ...
- 洛谷P1972 HH的项链【树状数组】
题目:https://www.luogu.org/problemnew/show/P1972 题意:给定一个长度为n的序列,数字表示珠子的种类.m次查询每次询问给定区间内珠子的种类数. 思路:可以说是 ...
- 洛谷 P1972 HH的项链 题解
题面 本题其实主要就这几点: 1.离线,以右端点排序(从小到大); 2.建立树状数组c[],c[i]表示从1~i中有多少种不同的数字: 3.对于每次查询的答案就是sum(r)-sum(l-1); 4. ...
- BZOJ1878 洛谷1972 HH的项链题解
洛谷链接 BZOJ链接 看到这样不用修改的题目,应该佷容易就联想到了离线来处理. 我们发现若将询问按照r来排序,排完后每次对答案有贡献的仅是每个颜色最后出现的位置 我们用next[i]表示i处颜色之前 ...
- 洛谷1972 HH的项链 树状数组查询区间内不同的数的数量
题目链接:https://www.luogu.com.cn/problem/P1972 题意大致是:给定一个序列长度为n,给出m个查询区间,要求响应是区间内不同的数的个数.为此我们考虑到树状数组的区间 ...
- 洛谷P1972 [SDOI2009]HH的项链 题解
[SDOI2009]HH的项链 题目背景 无 题目描述 HH 有一串由各种漂亮的贝壳组成的项链.HH 相信不同的贝壳会带来好运,所以每次散步完后,他都会随意取出一段贝壳,思考它们所表达的含义.HH 不 ...
- 洛谷 P1972 [SDOI2009]HH的项链【莫队算法学习】
P1972 [SDOI2009]HH的项链 题目背景 无 题目描述 HH 有一串由各种漂亮的贝壳组成的项链.HH 相信不同的贝壳会带来好运,所以每次散步完后,他都会随意取出一段贝壳,思考它们所表达的含 ...
- 洛谷 P1972 [SDOI2009]HH的项链 解题报告
P1972 [SDOI2009]HH的项链 题目描述 HH 有一串由各种漂亮的贝壳组成的项链.HH 相信不同的贝壳会带来好运,所以每次散步完后,他都会随意取出一段贝壳,思考它们所表达的含义.HH 不断 ...
- 洛谷——P1972 [SDOI2009]HH的项链(线段树)
P1972 [SDOI2009]HH的项链 HH 有一串由各种漂亮的贝壳组成的项链.HH 相信不同的贝壳会带来好运,所以每次散步完后,他都会随意取出一段贝壳,思考它们所表达的含义.HH 不断地收集新的 ...
随机推荐
- 在前台jsp页面中取得并使用后台放入域中变量的方法
定义成 js变量后,在js中也可以自由使用.
- laravel 命令行输出进度条
有时候我们想在命令行执行一些耗时的命令,我们可以利用 symfony 提供的进度条相关的类,来输出一个进度条,显示当前的处理进度. 参考:http://symfony.com/doc/current/ ...
- Chapter 2(算法)
附件列表 算法.jpg
- python3.5无法安装pip,报错ImportError: cannot import name 'HTTPSHandler'
本人系统为:centos6 解决方法: 1 安装openssl yum install openssl 2 安装openssl-devel yum install openssl-devel 3 ...
- 队列,event,multiprocess
队列:queue queue is especially useful in threaded programming when information must be exchanged safel ...
- Go_17:GoLang中如何使用多参数属性传参
我们常常因为传入的参数不确定而头疼不已,golang 为我们提供了接入多值参数用于解决这个问题.但是一般我们直接写已知代码即所有的值都知道一个一个塞进去就好了,但是绝大部分我们是得到用户的大量输入想通 ...
- java基础-回调函数(callback)
java基础-回调函数(callback) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 回调函数就是一个通过函数指针调用的函数.如果你把函数的指针(地址)作为参数传递给另一个函数 ...
- java基础-引用数据类型之二维数组(Array)
java基础-引用数据类型之二维数组(Array) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 之前我们学习过了Java的一维数组,所谓的二维数组就是元素是一堆一维数组的数组,换 ...
- vue相关安装命令
安装cnpm npm install cnpm -g --registry=https://registry.npm.taobao.org
- matlab和C语言实现最小二乘法
参考:https://blog.csdn.net/zengxiantao1994/article/details/70210662 Matlab代码: N = ; x = [ ]; y = [ ]; ...