BZOJ 4241: 历史研究 ( 回 滚 )
题目: 链接:https://www.lydsy.com/JudgeOnline/problem.php?id=4241
题意:给你一个长度为n序列,m次查询,每次询问 一段区间 最大的 a[ i ] * cnt [ i ] ( 重要度 * 出现次数)
思路: 就是 一个块 一个块 的处理,对于 那些 l , r 在同一个块的查询 就 暴力 解决 ,对于那些 l 在同一个块 , r 不在 同一块的 查询咧, 它们的 r 是从小到大排的,那么这里的 r 至少在下一块,因为在这一块的都暴力解决了,那么就搞两个指针 l , r , l 指向块尾加1,因为 l 可以刚好在块尾,so,要加1,然后 r 指向快尾,因为 r 至少下下一块嘛, 那就 先 r 向右直到到达 q [ i ] . r ,然后再 l,向左到 q [ i ] . l ,记录完答案后列, l 指针就 滚回 块尾+1,把影响消除就行了 ( 这里采用的方法 是 另一个数 P 等于 l 还没向左移动的时候的 ans 值 (代码中是tmp) , 然后移动 l ,跟新ans, 然后记录完答案 就 把 l 滚回 块尾+1, 然后重新让 ans = p , 那就等于 l 没动过嘛 )
#include<bits/stdc++.h>
#define LL long long
#define ULL unsigned long long
#define rep(i,j,k) for(int i=j;i<=k;i++)
#define dep(i,j,k) for(int i=k;i>=j;i--)
#define INF 0x3f3f3f3f
#define mem(i,j) memset(i,0,sizeof(i))
#define make(i,j) make_pair(i,j)
#define pb push_back
using namespace std;
const int N=1e5+;
int a[N],b[N],c[N],cnt[N],pos[N],n,m,block;
LL tmp,ans[N];
struct noq {
int l,r,id;
}q[N];
bool cmp(noq a,noq b) {
return pos[a.l]==pos[b.l]?a.r<b.r:pos[a.l]<pos[b.l];
}
LL query(int l,int r) { ///暴力求答案
int t[N]; rep(i,l,r) t[b[i]]=; LL ret=;
rep(i,l,r) ++t[b[i]],ret=max(ret,1LL*t[b[i]]*a[i]);
return ret;
}
void add(int x) {
++cnt[b[x]];
tmp=max(tmp,1LL*cnt[b[x]]*a[x]);
}
int slove(int qnum,int bnum) { ///处理 第 bnum 块, 现在 处理到 q[qnum] 这个查询
int i=qnum; int L=min(bnum*block,n); int l=L+,r=L; tmp=; ///L 即为块尾
rep(j,,n) cnt[j]=; ///初始化,每处理一个块 都要 搞一次的啦
for(;pos[q[i].l]==bnum;i++) {
if(pos[q[i].l]==pos[q[i].r]) {/// l,r 在同一块,暴力处理
ans[q[i].id]=query(q[i].l,q[i].r); continue;
}
while(r<q[i].r) add(++r); ///先移动 r 指针
LL p=tmp; ///记录 l 指针 移动前的 tmp 值
while(l>q[i].l) add(--l);
ans[q[i].id]=tmp; ///记录答案
tmp=p; ///还原 tmp
while(l<L+) --cnt[b[l++]]; /// l 滚回块尾+1
}
return i; ///处理完这一块后,处理到第i个查询
}
int main() {
scanf("%d %d",&n,&m);
block=sqrt(n);
rep(i,,n) {
scanf("%d",&a[i]); c[i]=a[i]; pos[i]=(i-)/block+;///一定要加1喔,因为slove的时候l,r初始化需要
}
int up=pos[n]; ///块数
sort(c+,c++n);
int newn=unique(c+,c++n)-(c+);
rep(i,,n) {
b[i]=lower_bound(c+,c++newn,a[i])-c;///数据太大,离散化a[i]
}
rep(i,,m) {
scanf("%d %d",&q[i].l,&q[i].r); q[i].id=i;
}
sort(q+,q++m,cmp);
int pp=; ///处理到的 q[i],pp即为i;
rep(i,,up) {
pp=slove(pp,i);
}
rep(i,,m) printf("%lld\n",ans[i]);
return ;
}
回滚 莫队 的 时间 复杂度 是 n * sqrt( n ) ;
BZOJ 4241: 历史研究 ( 回 滚 )的更多相关文章
- BZOJ.4241.历史研究(回滚莫队 分块)
题目链接 \(Description\) 长度为n的数列,m次询问,每次询问一段区间最大的 \(A_i*tm_i\) (重要度*出现次数) \(Solution\) 好像可以用莫队做,但是取max的操 ...
- bzoj4241/AT1219 历史研究(回滚莫队)
bzoj4241/AT1219 历史研究(回滚莫队) bzoj它爆炸了. luogu 题解时间 我怎么又在做水题. 就是区间带乘数权众数. 经典回滚莫队,一般对于延长区间简单而缩短区间难的莫队题可以考 ...
- BZOJ4241:历史研究(回滚莫队)
Description IOI国历史研究的第一人——JOI教授,最近获得了一份被认为是古代IOI国的住民写下的日记.JOI教授为了通过这份日记来研究古代IOI国的生活,开始着手调查日记中记载的事件. ...
- BZOJ 4241 历史研究
Description IOI国历史研究的第一人——JOI教授,最近获得了一份被认为是古代IOI国的住民写下的日记.JOI教授为了通过这份日记来研究古代IOI国的生活,开始着手调查日记中记载的事件. ...
- BZOJ4241历史研究——回滚莫队
题目描述 IOI国历史研究的第一人——JOI教授,最近获得了一份被认为是古代IOI国的住民写下的日记.JOI教授为了通过这份日记来研究古代IOI国的生活,开始着手调查日记中记载的事件. 日记中记录了连 ...
- 「JOISC 2014 Day1」历史研究 --- 回滚莫队
题目又臭又长,但其实题意很简单. 给出一个长度为\(N\)的序列与\(Q\)个询问,每个询问都对应原序列中的一个区间.对于每个查询的区间,设数\(X_{i}\)在此区间出现的次数为\(Sum_{X_{ ...
- BZOJ 4241: 历史研究——莫队 二叉堆
传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=4241 题意:N个int范围内的数,M次询问一个区间最大的(数字*出现次数)(加权众数),可以 ...
- bzoj 4241 历史研究——分块(区间加权众数)
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4241 套路:可以大力预处理,如果求区间加权众数,可以预处理i~j块(或 j 位置)的最大值, ...
- BZOJ 4241 历史研究(分块)
题意 题解 #include<iostream> #include<cstring> #include<cstdio> #include<cmath> ...
随机推荐
- Nature Biotechnology:人类基因研究走近平民 数据是基础解读更重要
Nature Biotechnology:人类基因研究走近平民 数据是基础解读更重要 5万美元可以做什么?最近,美国斯坦福大学教授斯蒂芬·夸克在国际著名学术期刊<自然·生物技术>发表论文宣 ...
- 基于【 centos7】二 || 系统时间与网络时间同步
# date // 查看系统时间 #hwclock // 查看硬件时间 # yum -y install ntp ntpdate 安装ntpdate工具 # ntpdate cn.pool.ntp.o ...
- 手把手教你如何用java8新特性将List中按指定属性排序,过滤重复数据
在java中常常会遇到这样一个问题,在实际应用中,总会碰到对List排序并过滤重复的问题,如果List中放的只是简单的String类型过滤so easy,但是实际应用中并不会这么easy,往往List ...
- SVN配置使用及移植
使用svn作为配置管理工具及其普遍的用于项目开发中,网上有很多关于svn的原理介绍及命令行管理教程.这里仅仅分享下个人配置及使用的过程,不通过命令行,可简单的上手操作.如有遗漏欢迎留言交流. 配置及使 ...
- 【推荐】 Neutralizer 安卓上特殊的均衡器
首先 直切正题 这个均衡器特殊就特殊在 会产生 特定频率的声音 根据声音来调整 自己喜欢的声音 下载地址: https://d-02.apkplz.org/dl.php?s=czlDeEt ...
- S2-033、S2-037
前言 S2-033漏洞和S2-032类似,也是由于开启了动态方法调用,action mapper中的执行的方法名可控,导致了ognl表达式注入. 正文 Rest插件中获取action mapper是用 ...
- python matplotlib绘制六种可视化图表
1. 折线图 绘制折线图,如果你数据不是很多的话,画出来的图将是曲折状态,但一旦你的数据集大起来,比如下面我们的示例,有100个点,所以我们用肉眼看到的将是一条平滑的曲线. 这里我绘制三条线,只要执行 ...
- git的使用(win7 64位)
下载安装 1.官方下载网址:https://git-scm.com/downloads: 2.安装十分简单,按照默认配置,一直点击next,最后点击install,即安装成功: 3.安装成功之后,则自 ...
- 2.原子变量 CAS算法
前面提到,使用volatile无法保证 变量状态的原子性操作,所谓原子性,就是不可再分 如:i++的原子性问题,i++ 的操作实际上分为三个步骤 "读-改-写" (1)保存i的值 ...
- js 实现复制功能的四种方式的优劣对比
今日网上浏览别人项目,看到有人用了document.execCommand这个属性,于是想起之前我选用Clipboard.js 来实现.对于这种不常用的属性还是不太放心,于是随手查了下关于复制的资料, ...