11235 - Frequent values
《算法竞赛入门经典-训练指南》P198
记录一下区间的左右边界就可以了
#include <iostream>
#include <stack>
#include <queue>
#include <cstdio>
#include <cstdlib>
#include <cmath>
#include <set>
#include <vector>
#include <cstring>
#include <algorithm> #define INF 0x7fffffff
#define N 100010
#define M 1000010
#define LL long long
#define mod 95041567 using namespace std; int arr[N];
int num[N][3];
int dp[N][20]; void RMQ_init(int len){
for(int j = 1; (1 << j) <= len; ++ j)
for(int i = 1; i + (1 << j) - 1 < len; ++ i)
dp[i][j] = max(dp[i][j - 1], dp[i + (1 << (j - 1))][j - 1]);
} int RMQ(int L, int R){
if(R < L) return 0;
else if(R == L) return dp[R][0];
int k = 0;
while((1 << (k + 1)) <= R - L + 1) ++ k;
return max(dp[L][k], dp[R - (1 << k) + 1][k]);
} int main()
{
int n, q;
// freopen("in.txt","r",stdin);
while(scanf("%d", &n) != EOF){
if(! n) break;
scanf("%d", &q);
for(int i = 0; i < n; ++ i) scanf("%d", &arr[i]);
for(int i = 0; i <= n + 2; ++ i)
for(int j = 0; j <= 20; ++ j)
dp[i][j] = 0;
arr[n] = INF;
int p = 0;
int len = 0;
for(int i = 1; i <= n; ++ i)
if(arr[i] != arr[i - 1]){
for(int j = p; j <= i - 1; ++ j){
num[j][0] = i - 1;
num[j][1] = p;
num[j][2] = len;
}
dp[len ++][0] = i - p;
p = i;
}
RMQ_init(len);
int L, R;
for(int i = 0; i < q; ++ i){
scanf("%d %d", &L, &R);
if(arr[L - 1] == arr[R - 1]){
printf("%d\n", R - L + 1);
continue;
}
//printf("%s\n", "++");
p = num[L - 1][0] - (L - 1) + 1;
p = max(p, R - num[R - 1][1]);
p = max(p, RMQ(num[L - 1][2] + 1, num[R - 1][2] - 1));
printf("%d\n", p);
}
}
return 0;
}
11235 - Frequent values的更多相关文章
- 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
2007/2008 ACM International Collegiate Programming Contest University of Ulm Local Contest Problem F ...
- 数据结构(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 / [UVA] 11235 - Frequent values [ST算法]
2007/2008 ACM International Collegiate Programming Contest University of Ulm Local Contest Problem F ...
- 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 线段树/RMQ
vjudge 上题目链接:UVA 11235 *******************************************************大白书上解释**************** ...
- UVA 11235 Frequent Values ---RMQ
大白书上的例题,具体讲解见大白书,最好用用一个Log数组直接求k,这样就是纯O(1)了 #include <iostream> #include <cstdio> #inclu ...
- POJ 3368 & UVA 11235 - Frequent values
题目链接:http://poj.org/problem?id=3368 RMQ应用题. 解题思路参考:http://blog.csdn.net/libin56842/article/details/4 ...
- UVa 11235 Frequent values (RMQ && 区间出现最多次的数的次数)
题意 : 给出一个长度为 n 的不降序序列,并且给出 q 个形如(L, R)的问询,问你这个区间出现的最多次的数的次数. 分析 : 很自然的想到将区间“缩小”,例如1 1 2 3 3 3就可以变成2 ...
随机推荐
- ha_innobase::open
http://mysql.taobao.org/monthly/2015/08/07/ /******************************************************* ...
- 函数buf_read_page_low
/********************************************************************//** Low-level function which r ...
- UVa 1648 (推公式) Business Center
题意: 有一种奇怪的电梯,每次只能向上走u个楼层或者向下走d个楼层 现在有m个这种电梯,求恰好n次能够到达的最小楼层数(必须是正数),最开始默认位于第0层. 分析: 假设电梯向上走x次,则向下走n-x ...
- linux的HugePage与oracle amm关系
如果Oracle 是11g以后的版本,那么默认创建的实例会使用Automatic Memory Management (AMM)的特性,该特性与HugePage不兼容. 在设置HugePage之前需 ...
- Android Studio 我常用快捷键
0. Ctrl+Alt+L 格式化代码 Ctrl+Alt+O 优化导入的类 1. 重载方法 Ctrl+O 2.Ctrl+shift+Enter:自动匹配相对应的语法结构,比如if,do-while,t ...
- UVALive 4287 Proving Equivalences(缩点)
等价性问题,给出的样例为 a->b的形式,问要实现全部等价(即任意两个可以互相推出),至少要加多少个形如 a->b的条件. 容易想到用强连通缩点,把已经实现等价的子图缩掉,最后剩余DAG. ...
- LA 3708 Graveyard 墓地雕塑 NEERC 2006
在一个周长为 10000 的圆上等距分布着 n 个雕塑.现在又有 m 个新雕塑加入(位置可以随意摆放),希望所有 n + m 个雕塑能在圆周上均匀分布.这就需要移动一些原有的雕塑.要求 n 个雕塑移动 ...
- AWK print学习
Awk是一种处理结构数据并输出格式化结果的编程语言, Awk 是其作者 "Aho,Weinberger,Kernighan" 的简称. Awk通常被用来进行格式扫描和处理.通过扫描 ...
- 【又见LCS】NYOJ-37 回文字符串
[题目链接] 回文字符串 时间限制:3000 ms | 内存限制:65535 KB 难度:4 描述 所谓回文字符串,就是一个字符串,从左到右读和从右到左读是完全一样的,比如"aba& ...
- SharePoint 2010 列表项事件接收器 ItemAdded 的使用方法
列表项事件处理器是继承于Microsoft.SharePoint.SPItemEventReceiver的类,Microsoft.SharePoint.SPItemEventReceiver类提供了许 ...