[JOISC2014]歴史の研究/[BZOJ4241]历史研究
[JOISC2014]歴史の研究/[BZOJ4241]历史研究
题目大意:
一个长度为\(n(n\le10^5)\)的数列\(A(A_i\le10^9)\),定义一个元素对一个区间\([l,r]\)的贡献为\(A_i\times cnt(A_i)\),其中\(cnt(A_i)\)表示\(A_i\)在区间内的出现次数。\(q(q\le10^5)\)次询问,每次询问一个区间内贡献最大的元素的贡献。
思路:
分块。
\(cnt[i][j]\)表示前\(i\)块内\(j\)的出现次数,\(sum[i][j]\)表示\([begin(i),end(j)]\)的答案。
对\(A\)离散化后预处理\(cnt\)和\(sum\),询问时如果\(l,r\)在同一块直接暴力。如果不在同一块,则答案要么是\(sum[bel(l)+1,bel(r)-1]\),要么是\(l,r\)所在块中出现过的元素的贡献。
时间复杂度\(\mathcal O(n^{\frac32})\)。
源代码:
#include<cmath>
#include<cstdio>
#include<cctype>
#include<algorithm>
inline int getint() {
register char ch;
while(!isdigit(ch=getchar()));
register int x=ch^'0';
while(isdigit(ch=getchar())) x=(((x<<2)+x)<<1)+(ch^'0');
return x;
}
typedef long long int64;
const int N=1e5,M=317;
int n,m,q,block,a[N],b[N],bel[N],begin[M],end[M],tmp[N],cnt[M][N];
int64 sum[M][M];
inline int64 query(const int &l,const int &r) {
int64 ret=0;
if(bel[l]==bel[r]) {
for(register int i=l;i<=r;i++) {
tmp[a[i]]++;
ret=std::max(ret,(int64)b[a[i]]*tmp[a[i]]);
}
for(register int i=l;i<=r;i++) tmp[a[i]]--;
return ret;
}
ret=sum[bel[l]+1][bel[r]-1];
for(register int i=l;i<=end[bel[l]];i++) {
tmp[a[i]]++;
ret=std::max(ret,(int64)b[a[i]]*(tmp[a[i]]+cnt[bel[r]-1][a[i]]-cnt[bel[l]][a[i]]));
}
for(register int i=begin[bel[r]];i<=r;i++) {
tmp[a[i]]++;
ret=std::max(ret,(int64)b[a[i]]*(tmp[a[i]]+cnt[bel[r]-1][a[i]]-cnt[bel[l]][a[i]]));
}
for(register int i=l;i<=end[bel[l]];i++) tmp[a[i]]--;
for(register int i=begin[bel[r]];i<=r;i++) tmp[a[i]]--;
return ret;
}
int main() {
n=getint(),q=getint(),block=sqrt(n);
for(register int i=0;i<n;i++) {
a[i]=b[i]=getint();
bel[i]=i/block;
end[bel[i]]=i;
}
for(register int i=n-1;i>=0;i--) {
begin[bel[i]]=i;
}
std::sort(&b[0],&b[n]);
m=std::unique(&b[0],&b[n])-b;
for(register int i=0;i<n;i++) {
a[i]=std::lower_bound(&b[0],&b[m],a[i])-b;
cnt[bel[i]][a[i]]++;
}
for(register int i=1;i<=bel[n-1];i++) {
for(register int j=0;j<m;j++) {
cnt[i][j]+=cnt[i-1][j];
}
}
for(register int i=0;i<=bel[n-1];i++) {
for(register int j=begin[i];j<=end[i];j++) {
tmp[a[j]]++;
sum[i][i]=std::max(sum[i][i],(int64)b[a[j]]*tmp[a[j]]);
}
for(register int j=begin[i];j<=end[i];j++) tmp[a[j]]--;
for(register int j=i+1;j<=bel[n-1];j++) {
sum[i][j]=sum[i][j-1];
for(register int k=begin[j];k<=end[j];k++) {
tmp[a[k]]++;
sum[i][j]=std::max(sum[i][j],(int64)b[a[k]]*(tmp[a[k]]+cnt[j-1][a[k]]-(i!=0?cnt[i-1][a[k]]:0)));
}
for(register int k=begin[j];k<=end[j];k++) tmp[a[k]]--;
}
}
for(register int i=0;i<q;i++) {
const int l=getint()-1,r=getint()-1;
printf("%lld\n",query(l,r));
}
return 0;
}
[JOISC2014]歴史の研究/[BZOJ4241]历史研究的更多相关文章
- 【题解】BZOJ4241: 历史研究(魔改莫队)
[题解]BZOJ4241: 历史研究(魔改莫队) 真的是好题啊 题意 给你一个序列和很多组询问(可以离线),问你这个区间中\(\max\){元素出现个数\(\times\)元素权值} IOI国历史研究 ...
- BZOJ4241 历史研究
Description IOI国历史研究的第一人——JOI教授,最近获得了一份被认为是古代IOI国的住民写下的日记.JOI教授为了通过这份日记来研究古代IOI国的生活,开始着手调查日记中记载的事件. ...
- BZOJ4241历史研究——回滚莫队
题目描述 IOI国历史研究的第一人——JOI教授,最近获得了一份被认为是古代IOI国的住民写下的日记.JOI教授为了通过这份日记来研究古代IOI国的生活,开始着手调查日记中记载的事件. 日记中记录了连 ...
- BZOJ4241 历史研究 莫队 堆
欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目 Description IOI国历史研究的第一人——JOI教授,最近获得了一份被认为是古代IOI国的住民写下的日记.JO ...
- BZOJ4241:历史研究(回滚莫队)
Description IOI国历史研究的第一人——JOI教授,最近获得了一份被认为是古代IOI国的住民写下的日记.JOI教授为了通过这份日记来研究古代IOI国的生活,开始着手调查日记中记载的事件. ...
- [bzoj4241][历史研究] (分块)
Description IOI国历史研究的第一人——JOI教授,最近获得了一份被认为是古代IOI国的住民写下的日记.JOI教授为了通过这份日记来研究古代IOI国的生活,开始着手调查日记中记载的事件. ...
- BZOJ4241 历史研究(莫队)
如果分块的话与区间众数没有本质区别.这里考虑莫队. 显然莫队时的删除可以用堆维护,但多了一个log不太跑得过. 有一种叫回滚莫队的trick,可以将问题变为只有加入操作.按莫队时分的块依次处理,一块中 ...
- 2018.08.14 bzoj4241: 历史研究(回滚莫队)
传送们 简单的回滚莫队,调了半天发现排序的时候把m达成了n... 代码: #include<bits/stdc++.h> #define N 100005 #define ll long ...
- bzoj4241: 历史研究(回滚莫队)
传送门 这是一个叫做回滚莫队的神奇玩意儿 是询问,而且不强制在线,就决定是你了莫队 如果是每次插入一个数是不是很简单? 然而悲剧的是我们莫队的时候不仅要插入数字还要删除数字 那么把它变成只插入不就行了 ...
随机推荐
- iOS学习笔记(1)— UIView 渲染和内容管理
iOS中应用程序基本上都是基于MVC模式开发的.UIView就是模型-视图-控制器中的视图,在iOS终端上看到的.摸到的都是UIView. UIView在屏幕上定义了一个矩形区域和管理区域内容的接口. ...
- 20155303狄惟佳预备作业三Linux学习笔记
20155303狄惟佳预备作业三Linux学习笔记 初次接触Ubuntu系统以及Linux内核,了解了其产生的历史,从感性来讲,深深吸引我的是其中蕴含的珍贵的开源精神,以及Stallman等人对&qu ...
- Servlet笔记5--设置欢迎页面及HTTP状态码404、500
欢迎页面: 代码详解: web.xml配置文件: <?xml version="1.0" encoding="UTF-8"?> <web-ap ...
- Spring4笔记1--Spring概述、IoC
Spring概述: Spring框架: Spring 由 20 多个模块组成,它们可以分为数据访问/集成(Data Access/Integration).Web.面向切面编程(AOP, Aspec ...
- numpy之ones,array,asarray
from:http://blog.csdn.net/gobsd/article/details/56485177 numpy.ones() 废话少说直接上代码 >>> np.ones ...
- Java高性能并发编程——线程池
在通常情况下,我们使用线程的时候就去创建一个线程,这样实现起来非常简便,但是就会有一个问题: 如果并发的线程数量很多,并且每个线程都是执行一个时间很短的任务就结束了,这样频繁创建线程就会大大降低系统的 ...
- 【读书笔记::深入理解linux内核】内存寻址【转】
转自:http://www.cnblogs.com/likeyiyy/p/3837272.html 我对linux高端内存的错误理解都是从这篇文章得来的,这篇文章里讲的 物理地址 = 逻辑地址 – 0 ...
- ip_local_deliver && ip_local_deliver_finish
当ip包收上来,查路由,发现是发往本地的数据包时,会调用ip_local_deliver函数: ip_local_deliver中对ip分片进行重组,经过LOCAL_IN钩子点,然后调用ip_loca ...
- leetcode之 两数之和
# -*- coding: utf-8 -*- # @Time : 2018/9/27 21:41 # @Author : cxa # @File : twonum.py # @Software: P ...
- C 数据结构堆
引言 - 数据结构堆 堆结构都很耳熟, 从堆排序到优先级队列, 我们总会看见它的身影. 相关的资料太多了, 堆 - https://zh.wikipedia.org/wiki/%E5%A0%86%E7 ...