题目传送门

 /*
题意:从i开始,之前出现过的就是之前的值,否则递增,问第p个数字是多少
莫队算法:先把a[i+p-1]等效到最前方没有它的a[j],问题转变为求[l, r]上不重复数字有几个,裸莫队:)
*/
#include <cstdio>
#include <algorithm>
#include <map>
#include <set>
#include <vector>
#include <cmath>
#include <cstring>
using namespace std; const int MAXN = 2e6 + ;
const int INF = 0x3f3f3f3f;
map<int, int> table;
vector<int> V[MAXN];
int cnt[MAXN];
int a[MAXN];
int ans[MAXN];
struct Data
{
int b, l, r, id;
Data () {}
Data (int b, int l, int r, int id) : b (b), l (l), r (r), id (id) {};
}data[MAXN];
int n, m;
int ret; bool cmp(Data x, Data y)
{
if (x.b == y.b) return x.r < y.r;
else return x.b < y.b;
} void updata(int v)
{
if (v == ) ret++;
else if (v == ) ret--;
} void Modui(void)
{
sort (data+, data++m, cmp);
memset (cnt, , sizeof (cnt)); int l = , r = ; ret = ;
for (int i=; i<=m; ++i)
{
while (data[i].l < l)
{
++cnt[a[--l]];
if (cnt[a[l]] == ) ret++;
}
while (data[i].l > l)
{
--cnt[a[l]];
if (cnt[a[l]] == ) ret--;
l++;
}
while (data[i].r > r)
{
++cnt[a[++r]];
if (cnt[a[r]] == ) ret++;
}
while (data[i].r < r)
{
--cnt[a[r]];
if (cnt[a[r]] == ) ret--;
r--;
} ans[data[i].id] = ret;
} for (int i=; i<=m; ++i)
{
printf ("%d\n", ans[i]);
}
} int main(void) //Gym - 100496D Data Mining
{
// freopen ("D.in", "r", stdin);
freopen ("data.in", "r", stdin);
freopen ("data.out", "w", stdout); while (scanf ("%d", &n) == )
{
table.clear ();
for (int i=; i<=n; ++i) V[i].clear (); int num = ;
for (int i=; i<=n; ++i)
{
scanf ("%d", &a[i]);
a[i] = table[a[i]] ? table[a[i]] : table[a[i]] = ++num;
V[a[i]].push_back (i);
} int block = (int) sqrt (n * 1.0);
scanf ("%d", &m);
for (int i=; i<=m; ++i)
{
int l, r; scanf ("%d%d", &l, &r);
r = l + r - ;
int pos = lower_bound (V[a[r]].begin (), V[a[r]].end (), l) - V[a[r]].begin ();
r = V[a[r]][pos];
data[i] = Data (l / block, l, r, i);
} Modui ();
} return ;
}

莫队算法 Gym - 100496D Data Mining的更多相关文章

  1. BZOJ 2038: [2009国家集训队]小Z的袜子(hose) [莫队算法]【学习笔记】

    2038: [2009国家集训队]小Z的袜子(hose) Time Limit: 20 Sec  Memory Limit: 259 MBSubmit: 7687  Solved: 3516[Subm ...

  2. Codeforces617 E . XOR and Favorite Number(莫队算法)

    XOR and Favorite Number time limit per test: 4 seconds memory limit per test: 256 megabytes input: s ...

  3. BZOJ-2038 小Z的袜子(hose) 莫队算法

    2038: [2009国家集训队]小Z的袜子(hose) Time Limit: 20 Sec Memory Limit: 259 MB Submit: 5573 Solved: 2568 [Subm ...

  4. bzoj 2308 小Z的袜子(莫队算法)

    小Z的袜子 [题目链接]小Z的袜子 [题目类型]莫队算法 &题解: 莫队算法第一题吧,建议先看这个理解算法,之后在参考这个就可以写出简洁的代码 我的比第2个少了一次sort,他的跑了1600m ...

  5. 【bzoj5016】[Snoi2017]一个简单的询问 莫队算法

    题目描述 给你一个长度为N的序列ai,1≤i≤N和q组询问,每组询问读入l1,r1,l2,r2,需输出 get(l,r,x)表示计算区间[l,r]中,数字x出现了多少次. 输入 第一行,一个数字N,表 ...

  6. 【bzoj4542】[Hnoi2016]大数 莫队算法

    题目描述 给出一个数字串,多次询问一段区间有多少个子区间对应的数为P的倍数.其中P为质数. 输入 第一行一个整数:P.第二行一个串:S.第三行一个整数:M.接下来M行,每行两个整数 fr,to,表示对 ...

  7. 【bzoj3585/bzoj3339】mex/Rmq Problem 莫队算法+分块

    原文地址:http://www.cnblogs.com/GXZlegend/p/6805283.html 题目描述 有一个长度为n的数组{a1,a2,...,an}.m次询问,每次询问一个区间内最小没 ...

  8. 【bzoj4940】[Ynoi2016]这是我自己的发明 DFS序+树上倍增+莫队算法

    题目描述 给一个树,n 个点,有点权,初始根是 1. m 个操作,每次操作: 1. 将树根换为 x. 2. 给出两个点 x,y,从 x 的子树中选每一个点,y 的子树中选每一个点,如果两个点点权相等, ...

  9. 【bzoj2506】calc 根号分治+STL-vector+二分+莫队算法

    题目描述 给一个长度为n的非负整数序列A1,A2,…,An.现有m个询问,每次询问给出l,r,p,k,问满足l<=i<=r且Ai mod p = k的值i的个数. 输入 第一行两个正整数n ...

随机推荐

  1. [K3Cloud] QueryService使用注意事项

    QueryServlice是目前查询数据非常好用的服务,但目前在使用过程中由于使用不当产生不少问题,下面将一一解答: 1.在查询一些实体关键字段如实体主键.分录序号时,条件中的别名怎么会变来变去?   ...

  2. Netbeans工具使用记录

     #自动换行设置 工具->选项->编辑器->格式设置

  3. 【IntelliJ 】IntelliJ IDEA 自动导入包 快捷方式 关闭重复代码提示

    idea可以自动优化导入包,但是有多个同名的类调用不同的包,必须自己手动Alt+Enter设置 设置idea导入包 勾选标注 1 选项,IntelliJ IDEA 将在我们书写代码的时候自动帮我们优化 ...

  4. Educational Codeforces Round 41 B、C、D

    http://codeforces.com/contest/961 B题 可以将长度为k的连续区间转化成1 求最大和 解析 简单尺取 #include <stdio.h> #include ...

  5. how to read openstack code : routes

    When coding a web system, you have to think about an important problem, how to map urls to logic. Op ...

  6. delphi的一些语法知识 以及参数传递问题,按引用方式传递参数,按值方式传递参数

    //delphi中exit,abort,break,continue 的区别 exit: 退出函数体abort: 遇到异常,安静处理,就是不显示不提示break: 退出当前循环体,包括for ,whi ...

  7. AES加密算法的C++实现

    摘要:作为新一代的加密标准,AES 旨在取代 DES(请看<DES加密算法的C++实现>),以适应当今分布式开放网络对数据加密安全性的要求.本文在分析了 AES 加密原理的基础上着重说明了 ...

  8. kendo datepicker汉化

    kendo grid 支持多语言,包括的语言有非常多种.一般默认情况是使用en,可是对于国内市场的话我们须要使用汉字.不墨迹了.     <link href="http://cdn. ...

  9. JPG文件格式

    开始:0xFF 0xD8 结束:0xFF 0xD9 文件的宽高:0xFF 0xC0 之后隔二个字节(0x11 0x08 这二个字节一般是固定的.描述这个块的长度.) 然后用四个字节来存储图片的高和宽0 ...

  10. JfreeChart的使用1

    JfreeChart的使用 来自: 克洛泽大地(DREG) 2008-07-03 14:35:11 先从网上找点介绍. 一.简介 WW 的发展使得基于因特网的应用程序不再局限于静态或者简单的动态内容提 ...