[bzoj4241][历史研究] (分块)
Description
Input
Output
Sample Input
Sample Output
HINT
Source
JOI 2013~2014 春季training合宿 竞技1 By PoPoQQQ
Solution
时限很仁慈,毕竟这题正解就是分块(~常数大的写法慢成狗)
对序列分块,离散化一下,用桶记录出现次数,用块做一个前缀和,再用块的数量的平方的时间跑一个o(x^2)的暴力rmq,就可以预处理所有的初值。
最后对每个询问还是一样的套路,整块的就不枚,直接调用,不完整块的就暴力求解(~你的程序怎么越来越丑(man)了)
//Kaiba_Seto 20170120
//orz cjkmao
#include <math.h>
#include <stdio.h>
#include <memory.h>
#include <algorithm>
#define MaxN 100010
#define MaxS 350
#define RG register
#define inline __inline__ __attribute__((always_inline))
#define L long long
#define dmin(a,b) ((a)<(b)?(a):(b))
#define dmax(a,b) ((a)>(b)?(a):(b)) namespace io{
#define MaxBuf 1<<22
#define _getc() ((S==T&&(T=(S=B)+fread(B,1,MaxBuf,stdin),S==T))?0:*S++)
char B[MaxBuf],*S=B,*T=B;
template<class Type>inline void Rin(RG Type &x){
x=;RG int c=getchar();RG bool b=;
for(;c<||c>;c=getchar())
if(c==)b=;
for(;c>&&c<;c=getchar())
x=(x<<)+(x<<)+c-;
if(b)x=-x;
}
}; int n,_q,a[MaxN],_reflection[MaxN],block_size,block_cnt[MaxS][MaxN],belong[MaxN],lef[MaxS],rig[MaxS];
L block_rmq[MaxS][MaxS]; struct _pair{
int first,*second;
bool operator < (const _pair &other) const {
return first < other.first;
}
}c[MaxN]; inline L query(RG int x,RG int y){
static int tmp_tim[MaxN],tmp_cnt[MaxN],T=;
RG int _l=belong[x],_r=belong[y];
RG L res=block_rmq[_l+][_r-]; ++T;
if(_l == _r){
for(RG int i=x;i<=y;i++){
if(tmp_tim[a[i]] != T){
tmp_tim[a[i]]=T; tmp_cnt[a[i]]=;
}
++tmp_cnt[a[i]];
res=dmax(res,(L) _reflection[a[i]] * tmp_cnt[a[i]]);
}
return res;
}
for(RG int i=x;i<=:: rig[_l];i++){
if(tmp_tim[a[i]] != T){
tmp_tim[a[i]]=T; tmp_cnt[a[i]]=block_cnt[_r-][a[i]]-block_cnt[_l][a[i]];
}
++tmp_cnt[a[i]];
res=dmax(res,(L) _reflection[a[i]] * tmp_cnt[a[i]]);
}
for(RG int i=:: lef[_r];i<=y;i++){
if(tmp_tim[a[i]] != T){
tmp_tim[a[i]]=T; tmp_cnt[a[i]]=block_cnt[_r-][a[i]]-block_cnt[_l][a[i]];
}
++tmp_cnt[a[i]];
res=dmax(res,(L) _reflection[a[i]] * tmp_cnt[a[i]]);
}
return res;
} int main(){
io::Rin(n),io::Rin(_q);
block_size=static_cast<int>(sqrt(n)+1e-);
for(RG int i=;i<=n;i++)
io::Rin(c[i].first),c[i].second=&a[i];
std::sort(c+,c++n);
for(RG int i=,m=;i<=n;i++){
if(i== || c[i].first != c[i-].first)
_reflection[++m]=c[i].first;
*c[i].second=m;
}
for(RG int i=;i<=n;i++)
belong[i]=(i-)/block_size+;
for(RG int i=;i<=n;i++)
block_cnt[belong[i]][a[i]]++;
for(RG int i=;(i-)*block_size+<=n;i++)
lef[i]=(i-)*block_size+,rig[i]=dmin(i*block_size,n);
for(RG int i=;:: lef[i];i++)
for(RG int j=;j<=n;j++)
block_cnt[i][j]+=block_cnt[i-][j];
for(RG int i=;lef[i];i++){
static int tmp_cnt[MaxN]; RG L ans=0LL;
memset(tmp_cnt,,sizeof tmp_cnt);
for(RG int j=lef[i];j<=n;j++){
++tmp_cnt[a[j]];
ans=dmax(ans,(L) _reflection[a[j]] * tmp_cnt[a[j]]);
if(j == rig[belong[j]])
:: block_rmq[i][belong[j]]=ans;
}
}
while(_q--){
RG int x,y;
io::Rin(x),io::Rin(y);
printf("%lld\n",query(x,y));
}
fclose(stdin);
return ;
}
[bzoj4241][历史研究] (分块)的更多相关文章
- bzoj4241 历史研究——分块
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4241 就是分块,预处理出从第 i 块到 j 位置的答案,以及从第 i 块到最后位置间每个数出 ...
- [JOISC2014]歴史の研究/[BZOJ4241]历史研究
[JOISC2014]歴史の研究/[BZOJ4241]历史研究 题目大意: 一个长度为\(n(n\le10^5)\)的数列\(A(A_i\le10^9)\),定义一个元素对一个区间\([l,r]\)的 ...
- 【题解】BZOJ4241: 历史研究(魔改莫队)
[题解]BZOJ4241: 历史研究(魔改莫队) 真的是好题啊 题意 给你一个序列和很多组询问(可以离线),问你这个区间中\(\max\){元素出现个数\(\times\)元素权值} IOI国历史研究 ...
- 【BZOJ4241】历史研究 分块
[BZOJ4241]历史研究 Description IOI国历史研究的第一人——JOI教授,最近获得了一份被认为是古代IOI国的住民写下的日记.JOI教授为了通过这份日记来研究古代IOI国的生活,开 ...
- BZOJ4241 历史研究
Description IOI国历史研究的第一人——JOI教授,最近获得了一份被认为是古代IOI国的住民写下的日记.JOI教授为了通过这份日记来研究古代IOI国的生活,开始着手调查日记中记载的事件. ...
- BZOJ4241 历史研究 莫队 堆
欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目 Description IOI国历史研究的第一人——JOI教授,最近获得了一份被认为是古代IOI国的住民写下的日记.JO ...
- BZOJ4241历史研究——回滚莫队
题目描述 IOI国历史研究的第一人——JOI教授,最近获得了一份被认为是古代IOI国的住民写下的日记.JOI教授为了通过这份日记来研究古代IOI国的生活,开始着手调查日记中记载的事件. 日记中记录了连 ...
- BZOJ4241:历史研究(回滚莫队)
Description IOI国历史研究的第一人——JOI教授,最近获得了一份被认为是古代IOI国的住民写下的日记.JOI教授为了通过这份日记来研究古代IOI国的生活,开始着手调查日记中记载的事件. ...
- BZOJ4241 历史研究(莫队)
如果分块的话与区间众数没有本质区别.这里考虑莫队. 显然莫队时的删除可以用堆维护,但多了一个log不太跑得过. 有一种叫回滚莫队的trick,可以将问题变为只有加入操作.按莫队时分的块依次处理,一块中 ...
随机推荐
- 使用JS准确获取URL网址中参数的几种方法
记录下使用JS准确获取URL网址中参数的方法: 参考链接1. https://blog.csdn.net/Zhihua_W/article/details/54845945?utm_source=bl ...
- 词典(一) 跳转表(Skip table)
词典,顾名思义,就是通过关键码来查询的结构.二叉搜索树也可以作为词典,不过各种BST,如AVL树.B-树.红黑树.伸展树,结构和操作比较复杂,而且理论上插入和删除都需要O(logn)的复杂度. 在词典 ...
- [Swift通天遁地]一、超级工具-(10)使用地图视图MKMapView的相机功能实现创建三维地图
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★➤微信公众号:山青咏芝(shanqingyongzhi)➤博客园地址:山青咏芝(https://www.cnblogs. ...
- Kafka详解与总结(六)
索引 稀疏存储,每隔一定字节的数据建立一条索引(这样的目的是为了减少索引文件的大小). 下图为一个partition的索引示意图: 注: 现在对6.和8建立了索引,如果要查找7,则会先查找到8然后,再 ...
- 【原创】Maven安装和配置
ι 版权声明:本文为博主原创文章,未经博主允许不得转载. 前提 利用maven进行java项目或J2EE项目开发,要求电脑已配置java开发环境(JDK) 下载 下载地址:http://maven.a ...
- java项目怎么打jar包(项目中包含第三方jar包)
1,右键选中项目,点击Export导出,找到java,选择第三个Runnable JAR file, 2,在Launch configuration中,填入程序的入口(有main方法的类), 然后 ...
- 专题三:自定义Web服务器
前言: 经过前面的专题中对网络层协议和HTTP协议的简单介绍相信大家对网络中的协议有了大致的了解的, 本专题将针对HTTP协议定义一个Web服务器,我们平常浏览网页通过在浏览器中输入一个网址就可以看到 ...
- Integer / BigInteger / BigDecimal 方法
import java.math.BigDecimal; import java.math.*; public class Main{ public static void main(String[] ...
- CF822C Hacker, pack your bags!
思路: 对于一个区间[l, r],只需枚举所有满足r' < l并且二者duration之和为x的区间[l', r'],寻找其中二者cost之和最小的即可.于是可以开一个数组a[],a[i]表示所 ...
- 文档声明和HTML样式表
文档声明 不是注释也不是元素,总是在HTML的第一行 书写格式:<!DOCTYPE HTML> 是用于通知浏览器目前文档正使用哪一个HTML版本(相关属性 lang) 若不写文档声明,浏览 ...