题目大意是给出一个非降序排列的数组,然后n个询问,每次询问一个区间内出现次数最多的数的次数。

首先要弄清楚题目的是一个非降序的数组,那么说明相等的数都会在一起,类似于11223334569这样的,那么可以将其合并,由于这种多次区间询问的题一般用

到的是线段树或者RMQ,所以就往这方面去靠,用num[i]和cont[i]表示第i段的数值和出现的次数,val[i]表示位置i所在段的编号,lef[i]和ri[i]表示位置i所在段的左右端点

位置,那么对于每次查询(l,r)区间就分成了三段,ri[l]-l+1,r-lef[r]+1和中间一段,而中间的一段就完全是根据cont数组求的RMQ问题,然后三者取大的就好。

 #include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std; const int M = 1e5 + ;
int a[M],d[M][],cont[M],num[M];
int lef[M],ri[M],val[M];
int max(int x,int y) {return x>y?x:y;} void rmq(int x)
{
for (int i= ; i<=x ; i++) d[i][]=cont[i];
for (int j= ; (<<j)<=x ; j++)
for (int i= ; i+(<<j)-<x ; i++)
d[i][j]=max(d[i][j-],d[i+(<<(j-))][j-]);
} int rmq(int l,int r)
{
if (l>r) return ;
int k=;
while ((<<(k+))<=r-l+) k++;
return max(d[l][k],d[r-(<<k)+][k]);
} int main()
{
int n,q,i;
while (~scanf("%d",&n)&&n){
scanf("%d",&q);
for (i= ; i<=n ; i++) scanf("%d",a+i);
int ans=-M,j=;
memset(cont,,sizeof(cont));
for (i= ; i<=n ; i++)
{
if (a[i]!=ans)
{
val[j]=a[i];
ans=a[i];
int k=i,w=i;
while (ans==a[i]){
cont[j]++;
i++;
}
i--;
for ( ; k<=i ; k++)
{
num[k]=j;
lef[k]=w;
ri[k]=i;
}
j++;
}
}
j--;
rmq(j);
int l,r;
/* for (i=1 ; i<=j ; i++) cout<<val[i]<<" ";
cout<<endl;
for (i=1 ; i<=j ; i++) cout<<cont[i]<<" ";
cout<<endl;
for (i=1 ; i<=n ; i++) cout<<num[i]<<" ";
cout<<endl;
for (i=1 ; i<=n ; i++) cout<<lef[i]<<" ";
cout<<endl;
for (i=1 ; i<=n ; i++) cout<<ri[i]<<" ";
cout<<endl;*/
while (q--)
{
scanf("%d%d",&l,&r);
if (num[l]==num[r])
{
printf("%d\n",r-l+);
continue;
}
printf("%d\n",max(r-lef[r]+,max(rmq(num[ri[l]+],num[lef[r]-]),ri[l]-l+))); }
}
return ;
}

 

UVA 11235 (RMQ) 频繁出现的数值的更多相关文章

  1. Uva 11235 RMQ问题

    RMQ: 有一个不变的数组,不停的求一个区间的最小值. 使用倍增的思想优化到logN; d(i,j) 表示从 i 开始的,长度为2j的一段元素中的最小值. 那么状态转移方程: d(i,j) = min ...

  2. UVa 11235 RMQ

    首先讲一下RMQ算法的意思. RMQ(Range Minimum Query,RMQ)范围最小值,给出一个n个元素的数组,计算min(A[L],A[L+1],...,A[R-1],A[R]): 这里运 ...

  3. UVa 11235 (RMQ) Frequent values

    范围最值问题,O(nlogn)的预处理,O(1)的查询. 这个题就是先对这些数列进行游程编码,重复的元素只记录下重复的次数. 对于所查询的[L, R]如果它完全覆盖了某些连续的重复片段,那么查询的就是 ...

  4. uva 11235 RMQ范围最大值

    题目大意:给一个整数上升序列,对于一系列询问区间(i,j),回答这段区间出现次数最多值所出现的次数. 分析:一个上升序列,相同的值聚集在一起,把相同的值的区间看作一个整体,假设这样的整体有n个,把他们 ...

  5. UVA 11235 RMQ算法

    上次的湘潭赛的C题,用线段树敲了下还是WA,不知道为何,我已经注意了处理相同数据,然后他们当时用的RMQ. 所以学了下RMQ,感觉算法思想是一样的,RMQ用了DP或者是递推,由单个数到2^k往上推,虽 ...

  6. UVA 11235 Frequent values 线段树/RMQ

    vjudge 上题目链接:UVA 11235 *******************************************************大白书上解释**************** ...

  7. RMQ算法 以及UVA 11235 Frequent Values(RMQ)

    RMQ算法 简单来说,RMQ算法是给定一组数据,求取区间[l,r]内的最大或最小值. 例如一组任意数据 5 6 8 1 3 11 45 78 59 66 4,求取区间(1,8)  内的最大值.数据量小 ...

  8. UVA 11235 (游程编码+ST算法)

    题目链接:http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=23846 题目大意:给定一个升序序列,有q次询问,每次询问(L,R) ...

  9. UVa 12299 RMQ with Shifts(移位RMQ)

    p.MsoNormal { margin: 0pt; margin-bottom: .0001pt; text-align: justify; font-family: "Times New ...

随机推荐

  1. Swift自定义UINavigationController(背景颜色、背景图片、返回按钮设置、字体大小等)

    1.0  自定义UINavigationController时,背景图片.颜色等只需要设置一次,所以我们可以重写  initializa  这个方法来实现我们想要的效果 override  class ...

  2. java 代码块,静态代码块,构造器等的执行顺序

    写了一段测试代码,如下: public class ExecutionSequence extends fatherClass{    static{        System.out.printl ...

  3. java批量向oracle插入数据

    由于项目需要,需要将一个6M的txt中的数据插入到oracle数据表中.txt中的数据是每行一个词.经过统计,词总数是505040.为了看起来方便,我将我的所有方法写在类入口中,数据库的信息我会用te ...

  4. yii2-ueditor

    扩展下载(yii2.0-ueditor) 框架下载(Yii 2.0.6 高级版) 描述: 最佳适用于yii2.0 高级版(advanced)应用框架,对于基础板(basic)及其他框架要修改对应的命名 ...

  5. workerman 平滑重启

    <?phpuse Workerman\Worker;use Workerman\Lib\Timer; require_once '../../web/Workerman/Autoloader.p ...

  6. MySQL 事务 隔离级别

    前两天面试,问到了四种隔离级别,当时觉得大多数数据库都为read committed,结果没想到mysql是个例外.在此做一下隔离级别和各种数据库锁的使用. 首先说一下ACID四大特性: 四大特性   ...

  7. Linux系统服务之inetd

    [Linux系统服务之inetd] inetd的角色是作为Telnet和FTP等与网络服务器相关的进程的“超级服务器”.这是一个简单的道理:并不是全部的服务器进程(包括那些接受新的Telnet和FTP ...

  8. select字符串

    [select字符串] select通常用于选择某中的某一列.如有表Download: 通常用select选择某一列,如: 当select一个字符串时,则会返回如下值: 结论:select中传递一个字 ...

  9. 用BlazeMeter录制JMeter(三十五)测试脚本(转载)

    转载自 http://www.cnblogs.com/yangxia-test 工具: 1,JMeter 2,Chrome 3,BlazeMeter 4,SwitchyOmega(如果需要代理) 步骤 ...

  10. Oracle 入门

    一.安装Oracle 11g 服务端 服务端安装教程:https://jingyan.baidu.com/article/363872eccfb9266e4aa16f5d.html 二.安装客户端 客 ...