LOJ2874 JOISC2014 历史研究 分块、莫队
看到出现次数自然地考虑莫队。
但是发现如果需要删除并动态维护答案的话,则要用一个堆来维护答案,增加了一个\(log\)。但是加入操作却没有这个\(log\),所以我们考虑避免删除操作。
分块,设\(l_i,r_i\)表示第\(i\)个块的左右端点,设\(f_{i,j}\)表示区间\([l_i,r_j]\)的答案,可以枚举\(i\)然后枚举\(j\)做到\(O(n\sqrt{n})\);
接下来将询问离线,对于每一组询问如果左右端点距离\(\leq 2\sqrt{n}\)则暴力计算答案,否则考虑其覆盖的整块\([p,q]\),则通过莫队将\([l_p,r_q]\)内所有数的出现次数统计下来,然后暴力将零散块的贡献进入出现次数数组并更新当前答案,最后把出现次数数组还原即可。复杂度\(O(n\sqrt{n})\)。
#include<bits/stdc++.h>
using namespace std;
int read(){
	int a = 0; char c = getchar(); bool f = 0;
	while(!isdigit(c)){f = c == '-'; c = getchar();}
	while(isdigit(c)){
		a = a * 10 + c - 48; c = getchar();
	}
	return f ? -a : a;
}
const int _ = 1e5 + 7 , S = sqrt(_) , T = _ / S + 10;
long long mx[T][T] , ans[_]; int arr[_] , tmp[_] , lsh[_] , N , Q , num;
struct query{
	int l , r , id , tL , tR;
	query(int _l , int _r , int _id){
		l = _l; r = _r; id = _id; tL = (l / S + 1) * S; tR = (r / S) * S - 1;
	}
	friend bool operator <(query A , query B){
		return A.tL < B.tL || A.tL == B.tL && A.tR < B.tR;
	}
}; vector < query > qry;
void add(int x){++tmp[arr[x]];} void del(int x){--tmp[arr[x]];}
signed main(){
#ifndef ONLINE_JUDGE
	freopen("in","r",stdin);
	freopen("out","w",stdout);
#endif
	N = read(); Q = read();
	for(int i = 0 ; i < N ; ++i) arr[i] = lsh[i] = read();
	sort(lsh , lsh + N); num = unique(lsh , lsh + N) - lsh - 1;
	for(int i = 0 ; i < N ; ++i) arr[i] = lower_bound(lsh , lsh + num + 1 , arr[i]) - lsh;
	for(int i = 0 ; i < N ; i += S){
		long long now = 0;
		for(int j = i ; j < N ; ++j){
			now = max(now , 1ll * ++tmp[arr[j]] * lsh[arr[j]]);
			if(j % S == S - 1 || j + 1 == N) mx[i / S][j / S] = now;
		}
		memset(tmp , 0 , sizeof(tmp));
	}
	for(int i = 1 ; i <= Q ; ++i){
		int p = read() - 1 , q = read() - 1; long long now = 0;
		if(q - p <= 2 * S){
			for(int k = p ; k <= q ; ++k)
				now = max(now , 1ll * ++tmp[arr[k]] * lsh[arr[k]]);
			for(int k = p ; k <= q ; ++k) tmp[arr[k]] = 0;
			ans[i] = now;
		}
		else qry.push_back(query(p , q , i));
	}
	sort(qry.begin() , qry.end()); int L = 0 , R = -1;
	for(auto t : qry){
		while(R < t.tR) add(++R); while(L > t.tL) add(--L);
		while(R > t.tR) del(R--); while(L < t.tL) del(L++);
		long long now = mx[L / S][R / S];
		for(int i = L - 1 ; i >= t.l ; --i)
			now = max(now , 1ll * ++tmp[arr[i]] * lsh[arr[i]]);
		for(int i = R + 1 ; i <= t.r ; ++i)
			now = max(now , 1ll * ++tmp[arr[i]] * lsh[arr[i]]);
		ans[t.id] = now;
		for(int i = t.l ; i < L ; ++i) --tmp[arr[i]];
		for(int i = t.r ; i > R ; --i) --tmp[arr[i]];
	}
	for(int i = 1 ; i <= Q ; ++i) printf("%lld\n" , ans[i]);
	return 0;
}
												
											LOJ2874 JOISC2014 历史研究 分块、莫队的更多相关文章
- BZOJ4241 历史研究(莫队)
		
如果分块的话与区间众数没有本质区别.这里考虑莫队. 显然莫队时的删除可以用堆维护,但多了一个log不太跑得过. 有一种叫回滚莫队的trick,可以将问题变为只有加入操作.按莫队时分的块依次处理,一块中 ...
 - 【BZOJ-3809】Gty的二逼妹子序列      分块 + 莫队算法
		
3809: Gty的二逼妹子序列 Time Limit: 80 Sec Memory Limit: 28 MBSubmit: 1072 Solved: 292[Submit][Status][Di ...
 - 2018.11.07 NOIP训练 L的鞋子(权值分块+莫队)
		
传送门 乱搞题. 我直接对权值分块+莫队水过了. 不过调了30min30min30min发现ststst表挂了是真的不想说什么233. 代码
 - HDU 5145 分块 莫队
		
给定n个数,q个询问[l,r]区间,每次询问该区间的全排列多少种. 数值都是30000规模 首先考虑计算全排列,由于有同种元素存在,相当于每次在len=r-l+1长度的空格随意放入某种元素即$\bin ...
 - bzoj 3585 mex - 线段树 - 分块 - 莫队算法
		
Description 有一个长度为n的数组{a1,a2,...,an}.m次询问,每次询问一个区间内最小没有出现过的自然数. Input 第一行n,m. 第二行为n个数. 从第三行开始,每行一个询问 ...
 - 【BZOJ4241】历史研究 分块
		
[BZOJ4241]历史研究 Description IOI国历史研究的第一人——JOI教授,最近获得了一份被认为是古代IOI国的住民写下的日记.JOI教授为了通过这份日记来研究古代IOI国的生活,开 ...
 - 【BZOJ2038】【2009国家集训队】小Z的袜子(hose)    分块+莫队
		
Description 作为一个生活散漫的人,小Z每天早上都要耗费很久从一堆五颜六色的袜子中找出一双来穿.终于有一天,小Z再也无法忍受这恼人的找袜子过程,于是他决定听天由命……具体来说,小Z把这N只袜 ...
 - BZOJ.3809.Gty的二逼妹子序列(分块 莫队)
		
题目链接 /* 25832 kb 26964 ms 莫队+树状数组:增加/删除/查询 都是O(logn)的,总时间复杂度O(m*sqrt(n)*logn),卡不过 莫队+分块:这样查询虽然变成了sqr ...
 - 分块+莫队||BZOJ3339||BZOJ3585||Luogu4137||Rmq Problem / mex
		
题面:P4137 Rmq Problem / mex 题解:先莫队排序一波,然后对权值进行分块,找出第一个没有填满的块,直接for一遍找答案. 除了bzoj3339以外,另外两道题Ai范围都是1e9. ...
 
随机推荐
- Class版本号和Java版本对应关系
			
1.背景 版本号不对,会报错,如下 2.版本对应情况 JDK 1.8 = 52 JDK 1.7 = 51 JDK 1.6 =50 JDK 1.5 = 49 JDK 1.4 = 48 JDK 1. ...
 - Python基础(三)--流程控制之if、while、for,break与continue
			
一.流程控制之if……else…… if语句是指编程语言中用来判定所给定的条件是否满足,根据判定的结果(真或假)决定执行给出的两种操作之一 if 条件1: 缩进的代码块 elif 条件2: 缩进的代码 ...
 - MySQL数据物理备份之tar打包备份
			
复制数据文件方式,可以使用cp或tar 1.停止服务 [root@localhost mysql]# systemctl stop mysqld [root@localhost mysql]# net ...
 - Flask拾遗总汇1
			
目录 1.flask的路由分发方式 2.请求响应相关 3.flask配置文件拾遗(config) 4.路由系统参数配置 4.1 可传入参数: 4.2 常用路由系统有以上五 5.反向生成URL: url ...
 - lua 的匹配规则
			
匹配规则 .(点): 与任何字符配对 %a: 与任何字母配对 %c: 与任何控制符配对(例如\n) %d: 与任何数字配对 %l: 与任何小写字母配对 %p: 与任何标点(punctuation)配对 ...
 - linux系统最大TCP连接数限制
			
2017-12-28 17:48:21 chenlin465373800 阅读数 16189 不太对 本博客为转载,原文请参见<a href="http://blog.51cto ...
 - linux 下 Google配置SwitchyOmega
			
本文是在linux配置shadowssocks中配置的,windows也可以 通过上一篇文章我们学会了如何科学上网, 但是我们使用SwitchyOmega时选择的是proxy的代理模式 就是说我们不 ...
 - Navicat Premium 12 永久使用办法
			
1.按步骤安装Navicat Premium,如果没有可以去官网下载:http://www.navicat.com.cn/download/navicat-premium 2.安装好后下载激活文件:h ...
 - docker更改默认存储路径
			
systemctl stop docker mkdir /data/docker cp -r /var/lib/docker/* /data/docker mv /var/lib/docker /va ...
 - Django学习(不定期更新)
			
基于luffy项目的疑问点解决 删除掉.git文件夹,应该是该项目不需要git 在git克隆代码之后,初始化git,自动创建git仓库需要的目录,这些文件夹存在于项目下的.git文件夹中 .git文件 ...