UVa 11235 Frequent values (RMQ && 区间出现最多次的数的次数)
题意 : 给出一个长度为 n 的不降序序列,并且给出 q 个形如(L, R)的问询,问你这个区间出现的最多次的数的次数。
分析 : 很自然的想到将区间“缩小”,例如1 1 2 3 3 3就可以变成2 1 3,构造出“数量数组”,这个数组实际上就是已经将原来区间分了块,但是问询的区间不可能就是这些“数量数组”构成的"块",不过先来想想问询的区间可不可能包含这里面的某些"块"?很显然是有可能的,那么从这些"块"中找出最大值显然就是经典的RMQ问题,用ST可以预处理并解决,但是对于不是这些"块"的该怎么办呢?还是从这些"块"入手,首先先给这些"块"升序编号,对于这些"块"我们可以知道在原来区间当中其左右端点,比如1 1 2 3 3 3,我们可以分成① ② ③三块,值分别是2、1、3,第一块的左端点是原区间的1,右端点是2,同理第二块左右端点都是3,第三块左右端点是4和5,这样做便构成了“数量数组”下标和原数组下标的一个映射,对于问询(L, R)我们能够知道L属于那一块,那么这一个块在(L,R)这个区间内贡献的相同的值的元素个数就是=>L所在的块的右端点 - L + 1(这里记作val_L),对于R也是同理可以得到val_R,那么最后答案就是 ans = max( RMQ(L和R之间包含的完整的块), max(val_L, val_R))。不过需要注意的是,如果此时L R同在一个块中的话,那么答案就是R-L+1了!
#include<bits/stdc++.h>
using namespace std;
;
];
int cnt[maxn], L[maxn], R[maxn], num[maxn], tot;
inline void RMQ_init()
{
; i<tot; i++) dp[i][] = cnt[i];
; (<<j)<=tot; j++){
; i+(<<j)-<n; i++){
dp[i][j] = max(dp[i][j-], dp[i+(<<(j-))][j-]);
}
}
}
int RMQ(int L, int R)
{
;
;
<<(k+)) <= R-L+) k++;
<<k)+][k]);
}
int main(void)
{
while(~scanf("%d", &n) && n){
scanf("%d", &q);
memset(cnt, , sizeof(cnt));
memset(L, , sizeof(L));
memset(R, , sizeof(R));
tot = ;///表示"块"的个数
int Last;
; i<n; i++){///接下来对原区间的每一个元素进行映射处理
scanf("%d", &arr[i]);
){
Last = arr[i];///记录当前“块”的具体值
L[tot] = i;///当前“块”的左端点是i
}
if(arr[i] == Last){///如果元素还是属于上一个“块”
cnt[tot]++;///“块”里面的元素+1
num[i] = tot;///当前下标i对应了tot这个块
R[tot] = i;///更新右界
}else{
tot++;///有不同于之前的元素出现了,就相当于出现了新的“块”给其一个编号
cnt[tot]++;///tot“块”内元素+1
Last = arr[i];
num[i] = tot;
L[tot] = R[tot] = i;
}
}
tot++;
RMQ_init();///O(nlogn)的预处理
while(q--){
int Left, Right;
scanf("%d %d", &Left, &Right);
Left--, Right--;
if(num[Left] == num[Right]){///如果同属一个“块”,则答案就是R - L + 1
printf();
continue;
}else{
, num[Right]-),
max(R[num[Left]]-Left+, Right-L[num[Right]]+));
printf("%d\n", ans);
}
}
}
;
}
UVa 11235 Frequent values (RMQ && 区间出现最多次的数的次数)的更多相关文章
- 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 Frequent Values ---RMQ
大白书上的例题,具体讲解见大白书,最好用用一个Log数组直接求k,这样就是纯O(1)了 #include <iostream> #include <cstdio> #inclu ...
- UVA 11235 Frequent values 线段树/RMQ
vjudge 上题目链接:UVA 11235 *******************************************************大白书上解释**************** ...
- UVA 11235 Frequent values(RMQ)
Frequent values TimeLimit:3000Ms , ... , an in non-decreasing order. In addition to that, you are gi ...
- UVA - 11235 Frequent values
2007/2008 ACM International Collegiate Programming Contest University of Ulm Local Contest Problem F ...
- [POJ] 3368 / [UVA] 11235 - Frequent values [ST算法]
2007/2008 ACM International Collegiate Programming Contest University of Ulm Local Contest Problem F ...
- POJ 3368 & UVA 11235 - Frequent values
题目链接:http://poj.org/problem?id=3368 RMQ应用题. 解题思路参考:http://blog.csdn.net/libin56842/article/details/4 ...
- 数据结构(RMQ):UVAoj 11235 Frequent values
Frequent values You are given a sequence of n integers a1 , a2 , ... , an in non-decreasing order. I ...
- poj 3368 Frequent values(RMQ)
/************************************************************ 题目: Frequent values(poj 3368) 链接: http ...
随机推荐
- 【VS开发】使用 NuGet 管理项目库
NuGet 使用 NuGet 管理项目库 Phil Haack 无论多么努力,Microsoft 也没办法提供开发人员所需要的每一个库. 虽然 Microsoft 在全球的员工人数接近 90,000, ...
- FPGA —— LED控制
第一次接触新东西的时候,难免会磕磕碰碰,不过遇到问题不要着急,慢慢来.原因总归是我们自己引起的,一步步找到问题的根源,然后彻底解决它,避免下次再犯. 在开始之前先分享一下工具:(Quartus II ...
- 洛谷 P2868 [USACO07DEC]观光奶牛Sightseeing Cows 题解
题面 这道题是一道标准的01分数规划: 但是有一些细节可以优化: 不难想到要二分一个mid然后判定图上是否存在一个环S,该环是否满足∑i=1t(Fun[vi]−mid∗Tim[ei])>0 但是 ...
- pyhton自动化项目编码以及命名规范
对于任何一个编程项目来说,都需要一个编码的规范以及标准,这里整理了一些Google python的命名规范以及python语言PEP8的编码规范. 一.命名规范 命名示例: module_name, ...
- python 序列 转换 各种操作
# 数据结构 字符串 列表 元组 数字序列# 10-19的整数# r1 = range(10,20)# print(r1)# print(type(r1))## # 19# print(r1[9])# ...
- Python自学笔记之计算机基础
osi七层协议应用层-表示层-会话层-传输层-网络层-数据链路层-物理层 无线网协议 ethernet 物理层:网线,光纤 数据链路层:arp协议 mac地址,广播 在广播域内传播 网络层:ip地址标 ...
- D - 秋实大哥与快餐店
秋实大哥与快餐店 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submit ...
- [转载]Linux运行模式及紧急、救援模式
运行模式 在Linux中,存在一个叫init(initialize)的进程,其进程号是1,该进程存在一个对应的配置文件inittab,叫做系统的运行级别配置文件,位置在/etc/inittab.(但是 ...
- eclipse控制台输出太多被顶掉问题
控制台空白处右键 属性
- Mac下的常用快捷键总结
由于在公司的时候是使用的Windows下进行开发工作,但是回家之后,有时候要使用自己的Mac进行开发等工作,那么流利的使用快捷键就变得尤其的重要. 1. 退出软件 cmd + q 2.将最前面的窗口最 ...