BZOJ 4241: 历史研究——莫队 二叉堆
传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=4241
题意:N个int范围内的数,M次询问一个区间最大的(数字*出现次数)(加权众数),可以离线。
似乎正解是分块。。。因为可以离线&&时限大,用莫队算法卡常水过了(捂脸)。
具体方法:先按莫队方法把询问排序,然后考虑转移。
把所有数字离散化,记录每个数的(数字*出现次数),当我们加入/拿走一个数的时候,更新这个值,并维护二叉堆。
复杂度:\(O(N \sqrt N log N)\)
/**************************************************************
Problem: 4241
User: will7101
Language: C++
Result: Accepted
Time:29968 ms
Memory:5984 kb
****************************************************************/
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int MAXN=100005;
void rd(int &x){
x=0; int ch=getchar();
while(ch<'0'||'9'<ch) ch=getchar();
while('0'<=ch&&ch<='9') x=x*10+ch-'0', ch=getchar();
}
int N, M, V, S, be[MAXN], a[MAXN], id[MAXN], di[MAXN], num[MAXN];
ll ans[MAXN], hp[MAXN];
inline void add(int x){
hp[id[x]]+=num[x];
for(int i=id[x], j; i>1; i=j){
j=i>>1;
if(hp[i]>hp[j]){
swap(hp[i], hp[j]);
swap(id[di[i]], id[di[j]]);
swap(di[i], di[j]);
}else break;
}
}
inline void del(int x){
hp[id[x]]-=num[x];
for(int i=id[x], j;; i=j){
j=hp[i<<1]>hp[i<<1|1]?i<<1:i<<1|1;
if(j>V) break;
if(hp[i]<hp[j]){
swap(hp[i], hp[j]);
swap(id[di[i]], id[di[j]]);
swap(di[i], di[j]);
}else break;
}
}
struct Qry{
int l, r, id;
bool operator<(const Qry &o)const{
if(be[l]==be[o.l]) return (be[l]&1)?r>o.r:r<o.r;
return l<o.l;
}
}Q[MAXN];
void init(){
sort(num+1, num+N+1); V=unique(num+1, num+N+1)-num-1;
for(int i=1; i<=N; ++i) a[i]=lower_bound(num+1, num+V+1, a[i])-num;
for(int i=1; i<=V; ++i) id[i]=di[i]=i;
}
int main(){
rd(N), rd(M);
for(int i=1; i<=N; ++i) rd(a[i]), num[i]=a[i];
while(S*S<=M) S++;
for(int i=0; i<=N; ++i) be[i]=i/S;
init();
for(int i=0; i<M; ++i) rd(Q[i].l), rd(Q[i].r), Q[i].id=i;
sort(Q, Q+M);
for(int i=0, l=1, r=0; i<M; ++i){
while(r<Q[i].r) add(a[++r]);
while(l>Q[i].l) add(a[--l]);
while(l<Q[i].l) del(a[l++]);
while(r>Q[i].r) del(a[r--]);
ans[Q[i].id]=hp[1];
}
for(int i=0; i<M; ++i) printf("%lld\n", ans[i]);
return 0;
}
BZOJ 4241: 历史研究——莫队 二叉堆的更多相关文章
- BZOJ.4241.历史研究(回滚莫队 分块)
题目链接 \(Description\) 长度为n的数列,m次询问,每次询问一段区间最大的 \(A_i*tm_i\) (重要度*出现次数) \(Solution\) 好像可以用莫队做,但是取max的操 ...
- BZOJ4241 历史研究 莫队 堆
欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目 Description IOI国历史研究的第一人——JOI教授,最近获得了一份被认为是古代IOI国的住民写下的日记.JO ...
- BZOJ 4241: 历史研究 ( 回 滚 )
题目: 链接:https://www.lydsy.com/JudgeOnline/problem.php?id=4241 题意:给你一个长度为n序列,m次查询,每次询问 一段区间 最大的 a[ i ...
- BZOJ 4241 历史研究
Description IOI国历史研究的第一人——JOI教授,最近获得了一份被认为是古代IOI国的住民写下的日记.JOI教授为了通过这份日记来研究古代IOI国的生活,开始着手调查日记中记载的事件. ...
- bzoj 4241 历史研究——分块(区间加权众数)
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4241 套路:可以大力预处理,如果求区间加权众数,可以预处理i~j块(或 j 位置)的最大值, ...
- BZOJ 4241 历史研究(分块)
题意 题解 #include<iostream> #include<cstring> #include<cstdio> #include<cmath> ...
- 【BZOJ 1129】[POI2008]Per 二叉堆
这个东西读完题之后,就能知道我们要逐位计算贡献.推一下式子,会发现,这一位的贡献,是当前剩余的数字形成的序列的总数,乘上所剩数字中小于s上这一位的数的个数与所剩数字的总数的比.所以我们维护“当前剩余的 ...
- luogu P4887 莫队二次离线
珂朵莉给了你一个序列$a$,每次查询给一个区间$[l,r]$ 查询$l≤i<j≤r$,且$ai⊕aj$的二进制表示下有$k$个$1$的二元组$(i,j)$的个数.$⊕$是指按位异或. 直接暴力莫 ...
- luogu P4887 模板 莫队二次离线 莫队 离线
LINK:模板莫队二次离线 很早以前学的知识点 不过 很久了忘了. 考虑暴力 :每次莫队更新的时候 尝试更新一个点到一个区间的答案 可以枚举二进制下位数为k的数字 看一下区间内的这种数字有多少个. 不 ...
随机推荐
- ADC关键性能指标及误区
ADC关键性能指标及误区 由于ADC产品相对于网络产品和服务器需求小很多,用户和集成商在选择产品时对关键指标的理解难免有一些误区,加之部分主流厂商刻意引导,招标规范往往有不少非关键指标作被作为必须符合 ...
- [洛谷P4035][JSOI2008]球形空间产生器
题目大意:给你$n$个点坐标,要你求出圆心 题解:随机化,可以随机一个点当圆心,然后和每个点比较,求出平均距离$r$,如果到这个点的距离大于$r$,说明离这个点远了,就给圆心施加一个向这个点的力:若小 ...
- JUC包中的分而治之策略-为提高性能而生
一.前言 本次分享我们来共同探讨JUC包中一些有意思的类,包含AtomicLong & LongAdder,ThreadLocalRandom原理. 二.AtomicLong & Lo ...
- BZOJ4034:[HAOI2015]树上操作——题解
http://www.lydsy.com/JudgeOnline/problem.php?id=4034 https://www.luogu.org/problemnew/show/P3178 有一棵 ...
- 分享几款常用的API/文档浏览器
1.Dash 支持平台:Mac iOS 官网:https://kapeli.com/dash 2.Zeal 支持平台:Linux Windows 官网:https://zealdocs.org/ G ...
- BZOJ2761 不重复的数字 【treap】
2761: [JLOI2011]不重复数字 Time Limit: 10 Sec Memory Limit: 128 MB Submit: 5517 Solved: 2087 [Submit][S ...
- HDOJ(HDU).1258 Sum It Up (DFS)
HDOJ(HDU).1258 Sum It Up (DFS) [从零开始DFS(6)] 点我挑战题目 从零开始DFS HDOJ.1342 Lotto [从零开始DFS(0)] - DFS思想与框架/双 ...
- AOJ.综合训练.2016-12-1
友情提示:不要复制粘贴,看完解析先自己尝试写一下,不行再看代码!祝AC愉快 @_@ A. 近似值计算 题意分析 根据公式,先用含有n的代数式表示出来pi,然后计算这个近似值和题目给出来的3.14159 ...
- AES encryption of files (and strings) in java with randomization of IV (initialization vector)
http://siberean.livejournal.com/14788.html Java encryption-decryption examples, I've seen so far in ...
- H5背景音乐自动播放(兼容微信IOS,进程后台切换自动停止播放,本文例子为Vue写法)
<template> <audio src="./static/music.mp3" id="bgMusic" preload="a ...