UVA 11235 频繁出现的数值 RMQ
题目链接:
http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&problem=2176
RMQ,就是范围最小值的缩写,这个算法是Tarjan 的 Sparse-Table 算法,复杂度为O(n*log(n)).
就是用数组d[i][j]表示范围[i,i+2^j-1]中的最小值。
然后有递推式
d[i][j] = min(d[i][j-1],d[i+2^(j-1)][j-1]).
有边界条件d[i][0] = A[i].
然后就能求出所有的d[i][j].查询时只需找出2^(k+1) <= R-L+1的最大的k值,取等号时,k要+1.
答案为min(d[L][k],d[R-(1<<k)+1][k]).这两个区间有重叠,木有关系的,不是吗?
本题用Sparse-Table算法,改成求最大值即可。具体解法采用游程编码。
如输入的数组为-1,-1,1,1,1,1,3,10,10,10.则能得到(-1,2),(1,4),(3,1),(10,3),(a,b)表示值为a的数有b个。
然后将数组分为4块,编号分别为1,2,3,4.用辅助数组num[i],left[i],right[i]记录位置i所在的块的编号,以及块的左端点和右端点位置。
数组 -1,-1,1,1,1,1,3,10,10,10.
num 1, 1,2,2,2,2,3,4, 4, 4.
left 1 , 1,3,3,3,3,7,8, 8, 8.
right 2, 2,6, 6,6,6,7,10,10,10
然后答案为max(right(L)-L+1 , R - left[R]+1, max (num[L]+ 1, num[R] - 1));
特判当L和R在同一段时答案是R-L+1.
当num[L]+1 > num[R]-1时,最大值为负无穷。
贴代码:
#include<cstdio>
#include<algorithm>
using namespace std;
const int N =;
int c;
//元素从1编到n
int d[N][],n,cnt[N],num[N],left[N],right[N];
void RMQ_init()
{
for(int i=; i<=c; ++i) d[i][] = cnt[i];
for(int j=; (<<j) <= c; ++j)
for(int i=; i+j-<=c; ++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()
{
// freopen("in.txt","r",stdin);
int n,Q,a;
while(scanf("%d",&n),n)
{
for(int i=; i<=n; ++i) cnt[i]=;
scanf("%d%d",&Q,&a);
int p = a;
c=,cnt[c] = ,num[] = c;
for(int i=; i<=n; ++i)
{
scanf("%d",&a);
if(a != p)
{
p = a;
++c;
}
++cnt[c];
num[i] = c;
}
int s =;
for(int i=; i<=c; ++i)
{
for(int j=; j<=cnt[i]; ++j)
left[s+j] = s+,right[s+j] = s+cnt[i];
s += cnt[i];
}
RMQ_init();
while(Q--)
{
int l,r;
scanf("%d%d",&l,&r);
if(num[l] == num[r])
{
printf("%d\n",r-l+);
continue;
}
int ans=right[l]-l+;
if(r-left[r]+ > ans) ans = r-left[r]+;
int d = RMQ(num[l]+,num[r]-);
if(d > ans) ans =d;
printf("%d\n",ans);
}
}
return ;
}
UVA 11235 频繁出现的数值 RMQ的更多相关文章
- UVa 11235 频繁出现的数值
https://vjudge.net/problem/UVA-11235 题意: 给出一个非降序排列的整数数组a1,a2,...,an,你的任务是对于一系列询问(i,j),回答ai,ai+1,...a ...
- UVA 11235 Frequent values 线段树/RMQ
vjudge 上题目链接:UVA 11235 *******************************************************大白书上解释**************** ...
- RMQ算法 以及UVA 11235 Frequent Values(RMQ)
RMQ算法 简单来说,RMQ算法是给定一组数据,求取区间[l,r]内的最大或最小值. 例如一组任意数据 5 6 8 1 3 11 45 78 59 66 4,求取区间(1,8) 内的最大值.数据量小 ...
- UVA 11235 (游程编码+ST算法)
题目链接:http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=23846 题目大意:给定一个升序序列,有q次询问,每次询问(L,R) ...
- UVA 11235 (RMQ) 频繁出现的数值
题目大意是给出一个非降序排列的数组,然后n个询问,每次询问一个区间内出现次数最多的数的次数. 首先要弄清楚题目的是一个非降序的数组,那么说明相等的数都会在一起,类似于11223334569这样的,那么 ...
- UVA 11235 Frequent values(RMQ)
Frequent values TimeLimit:3000Ms , ... , an in non-decreasing order. In addition to that, you are gi ...
- Uva 11235 RMQ问题
RMQ: 有一个不变的数组,不停的求一个区间的最小值. 使用倍增的思想优化到logN; d(i,j) 表示从 i 开始的,长度为2j的一段元素中的最小值. 那么状态转移方程: d(i,j) = min ...
- UVa 11235 RMQ
首先讲一下RMQ算法的意思. RMQ(Range Minimum Query,RMQ)范围最小值,给出一个n个元素的数组,计算min(A[L],A[L+1],...,A[R-1],A[R]): 这里运 ...
- UVA 11235 Frequent Values ---RMQ
大白书上的例题,具体讲解见大白书,最好用用一个Log数组直接求k,这样就是纯O(1)了 #include <iostream> #include <cstdio> #inclu ...
随机推荐
- aws在线技术峰会笔记-游戏解决方案
选项1:可以将aws的SDK嵌入到APP中. 选项2:Mobile Hub自动生成代码. 选项3:开源免费的游戏引擎.可视化脚本编程,实现客户端的逻辑代码. 用户管理 Cognito Identity ...
- 封装对MongoDB数据库的增删改查访问方法(基于MongoDB官方发布的C#驱动)
本文利用MongoDB官方发布的C#驱动,封装了对MongoDB数据库的增删改查访问方法.先用官方提供的mongo-csharp-driver ,当前版本为1.7.0.4714 编写数据库访问帮助类 ...
- 轻松解决Linux安装Eclipse方法
随着Linux的发展,很多人开始学习Linux系统,你了解Linux系统么?你是Linux系统的应用者么?本文为你详细介绍Linux安装Eclipse,为你在学习Linux安装Eclipse时起一定的 ...
- HDU-4534 郑厂长系列故事——新闻净化 AC自动机+DP
题意:给定一些单词,这些单词必须要是一个目标串的子串,同时给定一些串,这些串不能够出现在目标串中,其余一些串只会带来不同附加值.现在问满足前两者的情况下,要求附加值最大.数据给定一个原始串,现在要求在 ...
- 《K&R》中引用的几个排序算法(shellsort、)以及一个自己乱写的排序
留待期末考后更新... void shellsort(int v[], int n) { int gap, i, j, temp; ; gap > ; gap /= ) for(i = gap; ...
- HDU4511 AC自动机+dijkstra
题意: Description 终于放寒假了,小明要和女朋友一起去看电影.这天,女朋友想给小明一个考验,在小明正准备出发的时候,女朋友告诉他,她在电影院等他,小明过来的路线必须满足给定的规则: 1. ...
- c++ 文件读写模板
#include <fstream> using namespace std; int main() { ifstream fin("in.txt"); ofstrea ...
- python3 字典相关函数
python版本3.5 #Author by Liguangbo#_*_ coding:utf-8 _*_'''info={'No.1':'ligb','No.2':'donglx','No.3':' ...
- 7 -- Spring的基本用法 -- 7...
7.7 创建Bean的3种方式 ① 调用构造器创建Bean. ② 调用静态工厂方法创建Bean. ③ 调用实例工厂方法创建Bean. 7.7.1 使用构造器创建Bean实例. 使用构造器来创建Bean ...
- python语言技巧
一 在写之前 最好指定python的路径: #!/usr/bin/python python 在linux中需要添加编码方式:以免出现中文乱码 # -*- coding: UTF-8 –*- 二 ...