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> ...
随机推荐
- 数据库设计_ERMaster安装使用_PowerDesigner数据设计工具
数据库设计 1. 说在前面 项目开发的流程包括哪些环节 需求调研[需求调研报告]-- 公司决策层 (1) 根据市场公司需求分析公司是否需要开发软件来辅助日常工作 (2) 公司高层市场考察,市场分析,决 ...
- 02 servlet基础 生命周期 tomcat web.xml
新建web项目 – new Web Project – 选择:javaee 5.0 建包 – com.gzsxt.wang 新建class:FirstServlet – 继承:HttpServlet( ...
- ngix介绍
ngix能做什么? 1 反向代理 2 负载均衡 3 正向代理 4 HTTP服务器(动静分离) 1 反向代理 Reverse Proxy 是指以代理服务器来接受来自internet或者是客户端的连接请 ...
- 怎样手写一个Object.create()方法
Object.create()会将参数对象作为一个新创建的空对象的原型, 并返回这个空对象, 基于这个功能, 就有了下面这个Object.create()的手动实现: function _create ...
- AES密码算法详解(转自https://www.cnblogs.com/luop/p/4334160.html)
0 AES简介 我们知道数据加密标准(Data Encryption Standard: DES)的密钥长度是56比特,因此算法的理论安全强度是256.但二十世纪中后期正是计算机飞速发展的阶段,元器件 ...
- 在论坛中出现的比较难的sql问题:9(触发器专题 插入数据自动更新表数据)
原文:在论坛中出现的比较难的sql问题:9(触发器专题 插入数据自动更新表数据) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所 ...
- MarkDown 语法记录
Markdown是一种纯文本格式的标记语言.通过简单的标记语法,它可以使普通文本内容具有一定的格式. 为啥要用 MarkDown 呢? 优点 1.因为是纯文本,所以只要支持Markdown的地方都能获 ...
- C# Winform 设置窗口打开的特效
https://www.cnblogs.com/mq0036/p/6421946.html using System.Runtime.InteropServices; public class Win ...
- CAN总线上的消息单帧某个信号的值计算(C#)
public static ulong GetMotorolaSignalValue(byte[] data, int startBit, int bitLength) { ; , j =; i ...
- Linux 命令行:cURL 的十种常见用法
Linux 命令行:cURL 的十种常见用法 文章目录 1. 获取页面内容 2. 显示 HTTP 头 3. 将链接保存到文件 4. 同时下载多个文件 5. 使用 -L 跟随链接重定向 6. 使用 -A ...