/*
线段树区间合并
维护几个信息 到时候乱搞一下就好了
开始T了 有一种情况可以不用递归 直接算出来
*/
#include<iostream>
#include<cstdio>
#include<cstring>
#define maxn 100010
#define lc (k<<1)
#define rc (k<<1)+1
#define mid ((l+r)>>1)
using namespace std;
int n,m,a[maxn],ls[maxn*],rs[maxn*],ln[maxn*],rn[maxn*],s[maxn*];
int init(){
int x=,f=;char s=getchar();
while(s<''||s>''){if(s=='-')f=-;s=getchar();}
while(s>=''&&s<=''){x=x*+s-'';s=getchar();}
return x*f;
}
void Build(int k,int l,int r){
if(l!=r){
Build(lc,l,mid);
Build(rc,mid+,r);
s[k]=max(s[lc],s[rc]);
if(rn[lc]==ln[rc])
s[k]=max(s[k],rs[lc]+ls[rc]);
ln[k]=ln[lc];rn[k]=rn[rc];
ls[k]=ls[lc];rs[k]=rs[rc];
if(ls[lc]==mid-l+&&rn[lc]==ln[rc])
ls[k]=max(ls[k],ls[lc]+ls[rc]);
if(rs[rc]==r-mid&&rn[lc]==ln[rc])
rs[k]=max(rs[k],rs[rc]+rs[lc]);
}
else{
ls[k]=rs[k]=;ln[k]=rn[k]=a[l];s[k]=;
}
}
int Query(int k,int l,int r,int x,int y){
if(x<=l&&y>=r)return s[k];
int ret=,L,R;
if(y<=mid)return Query(lc,l,mid,x,y);
else if(x>mid)return Query(rc,mid+,r,x,y);
else{
if(rn[lc]==ln[rc]){
L=max(mid-rs[lc]+,x);
R=min(mid+ls[rc],y);
ret=mid-L++R-mid;
}
//ret=Query(lc,l,mid,max(mid-rs[lc]+1,x),mid)
//+Query(rc,mid+1,r,mid+1,min(mid+ls[rc],y));可以只结算出来 QAQ T了好几遍
ret=max(ret,Query(lc,l,mid,x,y));
ret=max(ret,Query(rc,mid+,r,x,y));
}
return ret;
}
int main()
{
while(){
n=init();if(n==)break;
m=init();
for(int i=;i<=n;i++)a[i]=init();
Build(,,n);
while(m--){
int L,R;
L=init();R=init();
printf("%d\n",Query(,,n,L,R));
}
}
return ;
}
/*
ST表做法 比较巧妙 时间差不多 空间大一些
*/
#include<iostream>
#include<cstdio>
#include<cstring>
#define maxn 100010
using namespace std;
int n,m,a[maxn],c[maxn],f[maxn][],lst[maxn],p[maxn];
int init(){
int x=,f=;char s=getchar();
while(s<''||s>''){if(s=='-')f=-;s=getchar();}
while(s>=''&&s<=''){x=x*+s-'';s=getchar();}
return x*f;
}
void Clear(){
memset(c,,sizeof(c));
memset(f,,sizeof(f));
memset(lst,,sizeof(lst));
}
void Get_p(){
for(int i=;i<=maxn-;i++)
for(int j=;j<=;j++)
if((<<j)>i){
p[i]=j-;break;
}
}
void Get_ST(){
for(int i=;i<=n;i++)f[i][]=c[i];
for(int j=;j<=;j++)
for(int i=;i+(<<j)-<=n;i++)
f[i][j]=max(f[i][j-],f[i+(<<j-)][j-]);
}
int Query(int l,int r){
if(l>r)return ;
int k=p[r-l+];
return max(f[l][k],f[r-(<<k)+][k]);
}
int main()
{
Get_p();
while(){
n=init();if(n==)break;m=init();
Clear();
for(int i=;i<=n;i++)a[i]=init();
for(int i=;i<=n;i++)
if(a[i]==a[i-])c[i]=c[i-]+;
else c[i]++;
for(int i=n;i>=;i--)
if(a[i]==a[i+])lst[i]=lst[i+];
else lst[i]=i;
Get_ST();
while(m--){
int L,R,mxx=,mx=;
L=init();R=init();
mxx=Query(lst[L]+,R);
mx=min(lst[L],R)-L+;
printf("%d\n",max(mxx,mx));
}
}
return ;
}

Poj 3368 Frequent values的更多相关文章

  1. POJ 3368 Frequent values 【ST表RMQ 维护区间频率最大值】

    传送门:http://poj.org/problem?id=3368 Frequent values Time Limit: 2000MS   Memory Limit: 65536K Total S ...

  2. poj 3368 Frequent values(RMQ)

    /************************************************************ 题目: Frequent values(poj 3368) 链接: http ...

  3. POJ 3368 Frequent values (基础RMQ)

    Frequent values Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 14742   Accepted: 5354 ...

  4. poj 3368 Frequent values(段树)

    Frequent values Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 13516   Accepted: 4971 ...

  5. POJ 3368 Frequent values RMQ ST算法/线段树

                                                         Frequent values Time Limit: 2000MS   Memory Lim ...

  6. poj 3368 Frequent values -Sparse-Table

    Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 16537   Accepted: 5981 Description You ...

  7. POJ 3368 Frequent values(RMQ 求区间出现最多次数的数字的次数)

    题目链接:http://poj.org/problem? id=3368 Description You are given a sequence of n integers a1 , a2 , .. ...

  8. poj 3368 Frequent values(RMQ)

    题目:http://poj.org/problem?id=3368 题意:给定n个数,顺序为非下降,询问某个区间内的数出现最多的数的 出现次数.. 大白书上的 例题..算是RMQ变形了, 对 原数组重 ...

  9. (简单) POJ 3368 Frequent values,RMQ。

    Description You are given a sequence of n integers a1 , a2 , ... , an in non-decreasing order. In ad ...

  10. POJ 3368 Frequent values(线段树区间合并)

    [题目链接] http://poj.org/problem?id=3368 [题目大意] 有一个有序序列,要求区间查询出现次数最多的数 [题解] 维护每个区间左端点和右端点,以及左右的长度,还有区间的 ...

随机推荐

  1. du和df不一致的解决方法

    df:disk free,统计的是当前系统中空闲的磁盘du:disk usage,统计的是正在使用的空闲的磁盘.如果一个文件被删除之后,使用这个文件的进程未重启,则会出现df和du不一致的情况. 解决 ...

  2. 转:SQL Case when 的使用方法

      Case具有两种格式.简单Case函数和Case搜索函数. --简单Case函数 CASE sex WHEN '1' THEN '男' WHEN '2' THEN '女' ELSE '其他' EN ...

  3. ExtJS 4 Grids 详解

    Grid Panel是ExtJS最常用的组件之一,它的功能非常丰富,提供了非常便捷的方法执行排序,分组,编辑数据. Basic Grid Panel 基本表格面板 让我们创建一个简单的表格,这有创建和 ...

  4. STM32自带的bool型变量

    这些标着位会让你的程序使用起来更方便. First you need to include "STM32f10x_type.h" /*布尔型变量*/typedef enum{FAL ...

  5. start-tomcat7.launch

    <?xml version="1.0" encoding="UTF-8" standalone="no"?> <launc ...

  6. Hadoop完全分布式集群安装

    转载请注明原地址,谢谢! 本文目的是教大家配置Hadoop的完全分布式的集群,除了完全分布式还有两种分别是单节点和伪分布式部署.伪分布式只需要一台虚拟机,配置的东西也相对较少,大多用作代码调试,大家稍 ...

  7. BZOJ 1208 宠物收养所

    Description 最近,阿Q开了一间宠物收养所.收养所提供两种服务:收养被主人遗弃的宠物和让新的主人领养这些宠物.每个领养者都希望领养到自己满意的宠物,阿Q根据领养者的要求通过他自己发明的一个特 ...

  8. TOP命令解析

    转自: http://www.cnblogs.com/yjf512/ 你不一定懂的cpu显示信息 2013-10-23 11:48 by 轩脉刃, 1688 阅读, 0 评论, 收藏, 编辑 在使用t ...

  9. 测试使用wiz来发布blog

    晚上尝试了下用wiz写随笔并发布,貌似成功了,虽然操作体验和方便性上不如word,但起码它集成了这个简单的功能可以让我用:如果能让我自动新建blog文章并自动定时更新发布就完美了.2013年7月5日1 ...

  10. 数据结构(二维线段树,差分): NOI2012 魔幻棋盘

    貌似想复杂了…… #include <iostream> #include <cstring> #include <cstdio> #define mid ((l+ ...