蒲公英

Description

我们把所有的蒲公英看成一个长度为\(n\)的序列(\(a_1,a_2,...a_n\)),其中\(a_i\)为一个正整数,表示第i棵蒲公英的种类的编号。

每次询问一个区间\([l,r]\),你需要回答区间里出现次数最多的是哪种蒲公英,如果有若干种蒲公英出现次数相同,则输出种类编号最小的那个。

注意,你的算法必须是在线的。

Input Data

第一行两整数\(n,m\),表示有\(n\)棵蒲公英,mm次询问。

接下来一行\(n\)个空格分隔的整数\(a_i\),表示蒲公英的种类。

接下来\(m\)行,每行两个整数\(l_0,r_0\)。令上次的查询结果为\(x\)(如果是第一次查询,则\(x=0\))。

令\(l=(l_0+x-1) mod (n+1), r=(r_0+x-1) mod (n+1)\)

Output Data

输出\(m\)行,每行一个整数,表示每次查询的结果。

Input / Output Sample

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

Data Limit

\(n \le 40000,m \le 50000,1 \le a_i \le 10^9n≤40000,m≤50000,1≤ai≤10^9\)

Problem Source

\(BZOJ2724\)

算法竞赛进阶指南\(P218-219\)


这道题和\(数列分块入门9\)蜜汁相似QAQ。

请自行参照我的\(数列分块入门9题解\)

这里仅放上代码QAQ——

代码

#include<bits/stdc++.h>
using namespace std;
#define MAXN 40005 int n, m, T;
int a[MAXN], b[MAXN], c[MAXN];
int d, f[2000][2000];
int s[MAXN];
vector<int> p[MAXN]; int Count( int l, int r, int x ){
return upper_bound( p[x].begin(), p[x].end(), r ) - lower_bound( p[x].begin(), p[x].end(), l );
} int Get( int l, int r ){
if ( b[l] == b[r] ){
int ans1(0), ans2(0);
for ( int i = l; i <= r; ++i ){
int t(Count( l, r, a[i] ));
if ( t > ans2 ) ans1 = a[i], ans2 = t;
if ( t == ans2 ) ans1 = min( ans1, a[i] );
}
return ans1;
}
int ans1(f[b[l] + 1][b[r] - 1]), ans2(Count( l, r, ans1 ));
for ( int i = l; b[l] == b[i]; ++i ){
int t(Count( l, r, a[i] ));
if ( t > ans2 ) ans1 = a[i], ans2 = t;
if ( t == ans2 ) ans1 = min( ans1, a[i] );
}
for ( int i = r; b[r] == b[i]; --i ){
int t(Count( l, r, a[i] ));
if ( t > ans2 ) ans1 = a[i], ans2 = t;
if ( t == ans2 ) ans1 = min( ans1, a[i] );
}
return ans1;
} int main(){
scanf( "%d%d", &n, &T );
d = 0;
while( ( 1 << d ) <= n ) d++;
d = (int)( n / sqrt( 2 * T * d ) );
for ( int i = 1; i <= n; ++i ){
scanf( "%d", &a[i] ); c[i] = a[i]; b[i] = ( i - 1 ) / d + 1;
}
sort( c + 1, c + n + 1 );
m = unique( c + 1, c + n + 1 ) - c - 1;
for ( int i = 1; i <= n; ++i ) a[i] = lower_bound( c + 1, c + m + 1, a[i] ) - c;
for ( int i = 1; i <= n; ++i ) p[a[i]].push_back(i); for ( int i = 1; i <= b[n]; ++i ){
memset( s, 0, sizeof s );
int ans1(0), ans2(0);
for ( int j = ( i - 1 ) * d + 1; j <= n; ++j ){
s[a[j]]++;
if ( s[a[j]] == ans2 ) ans1 = min( ans1, a[j] );
if ( s[a[j]] > ans2 ) ans1 = a[j], ans2 = s[a[j]];
if ( b[j + 1] != b[j] ) f[i][b[j]] = ans1;
}
} int x(0);
while( T-- ){
int l, r;
scanf( "%d%d", &l, &r );
l = ( l + x - 1 ) % n + 1; r = ( r + x - 1 ) % n + 1;
int t(min( l, r )); r = max( l, r ); l = t;
printf( "%d\n", x = c[Get( l, r )] );
}
return 0;
}

数列分块系列目录

数列分块入门1

数列分块入门2

数列分块入门3

数列分块入门4

数列分块入门5

数列分块入门6

数列分块入门7

数列分块入门8

数列分块入门9

蒲公英 <-

公主的朋友

「分块系列」「洛谷P4168 [Violet]」蒲公英 解题报告的更多相关文章

  1. 洛谷_Cx的故事_解题报告_第四题70

    1.并查集求最小生成树 Code: #include <stdio.h> #include <stdlib.h>   struct node {     long x,y,c; ...

  2. 洛谷 P4168 [Violet]蒲公英 解题报告

    P4168 [Violet]蒲公英 题目背景 亲爱的哥哥: 你在那个城市里面过得好吗? 我在家里面最近很开心呢.昨天晚上奶奶给我讲了那个叫「绝望」的大坏蛋的故事的说!它把人们的房子和田地搞坏,还有好多 ...

  3. 洛谷 P2317 [HNOI2005]星际贸易 解题报告

    P2317 [HNOI2005]星际贸易 题目描述 输入输出格式 输入格式: 输出格式: 如果可以找到这样的方案,那么输出文件output.txt中包含两个整数X和Y.X表示贸易额,Y表示净利润并且两 ...

  4. 洛谷 P3802 小魔女帕琪 解题报告

    P3802 小魔女帕琪 题目背景 从前有一个聪明的小魔女帕琪,兴趣是狩猎吸血鬼. 帕琪能熟练使用七种属性(金.木.水.火.土.日.月)的魔法,除了能使用这么多种属性魔法外,她还能将两种以上属性组合,从 ...

  5. 洛谷 P2606 [ZJOI2010]排列计数 解题报告

    P2606 [ZJOI2010]排列计数 题目描述 称一个\(1,2,...,N\)的排列\(P_1,P_2...,P_n\)是\(Magic\)的,当且仅当对所以的\(2<=i<=N\) ...

  6. 洛谷1303 A*B Problem 解题报告

    洛谷1303 A*B Problem 本题地址:http://www.luogu.org/problem/show?pid=1303 题目描述 求两数的积. 输入输出格式 输入格式: 两个数 输出格式 ...

  7. [洛谷P4168][Violet]蒲公英

    题目大意:有$n(n\leqslant4\times10^4)$个数,$m(m\leqslant5\times10^4)$个询问,每次问区间$[l,r]$内的众数,若相同输出最小的,强制在线. 题解: ...

  8. 洛谷 P4168 [Violet] 蒲公英

    历尽千辛万苦终于AC了这道题目... 我们考虑1个区间\([l,r]\), 被其完整包含的块的区间为\([L,R]\) 那么众数的来源? 1.\([l,L)\)或\((R,r]\)中出现的数字 2.\ ...

  9. 洛谷 P4137 Rmq Problem /mex 解题报告

    P4137 Rmq Problem /mex 题意 给一个长为\(n(\le 10^5)\)的数列\(\{a\}\),有\(m(\le 10^5)\)个询问,每次询问区间的\(mex\) 可以莫队然后 ...

随机推荐

  1. OpenStack☞网关协议

    一 动态页面与静态页面区别 静态页面:每一个网页都有一个固定的URL,且网页的URL以.html..htm..shtml等常见的形式为后缀. 网页内容已经发布到网站服务器上,无论是否有用户访问,每个静 ...

  2. Spring MVC 解决 Could not write JSON: No serializer found for class java.lang.Object

    Spring MVC 解决 Could not write JSON: No serializer found for class java.lang.Object 资料参考:http://stack ...

  3. Tenka1 Programmer Beginner Contest D IntegerotS(补)

    当时没做出来,官方题解没看懂,就看别人提交的代码,刚对着别人代码调了几组数据,才发现,思路差不多,不过,原来是这样实现啊,果然我还是很菜 思路:题目要求是选取的这些数字全部进行OR运算,结果<= ...

  4. Python--day25--抽象类

    什么是抽象类: 抽象类: #一切皆文件 import abc #利用abc模块实现抽象类 class All_file(metaclass=abc.ABCMeta): all_type='file' ...

  5. spring boot + thymeleaf 乱码问题

    spring boot + thymeleaf 乱码问题 hellotrms 发布于 2017/01/17 15:27 阅读 1K+ 收藏 0 答案 1 开发四年只会写业务代码,分布式高并发都不会还做 ...

  6. 2019-11-6-Roslyn-how-to-use-WriteLinesToFile-to-write-the-semicolons-to-file

    title author date CreateTime categories Roslyn how to use WriteLinesToFile to write the semicolons t ...

  7. 【75.28%】【codeforces 764B】Decoding

    time limit per test1 second memory limit per test256 megabytes inputstandard input outputstandard ou ...

  8. CF1146G Zoning Restrictions

    CF1146G Zoning Restrictions 网络流 h<=50? 直接都选择最大的,ans=n*h*h 最小割 考虑舍弃或者罚款 有一个>x就要罚款? 经典取值限制的模型:切糕 ...

  9. 51nod 范德蒙矩阵

    思路: 根据矩阵乘法的定义,G中的第i行第j列的元素 ai,j ,对答案的贡献为 ai,j∗ T中第j行的所有元素之和. 因此我们可以将T中根据每行的和进行排序.第i行的和可以通过公式 (ai^n−1 ...

  10. 2018-8-10-win10-uwp-商业游戏-1.2.1

    title author date CreateTime categories win10 uwp 商业游戏 1.2.1 lindexi 2018-08-10 19:16:50 +0800 2018- ...