题目描述

题目传送门

分析

因为询问是关于区间的,并且没有强制在线,所以能用莫队解决

但是还要支持查询区间内大于等于 \(a\),小于等于 \(b\) 的数的个数和数值的个数

所以还要套一个数据结构

比较好想的做法是对权值开一个数状数组

\(logn\) 修改,\(logn\) 查询

复杂度有点高

考虑莫队的本质是进行了 \(n\sqrt{m}\) 次修改和 \(m\) 次查询

我们的修改必须是 \(O(1)\) 的,但是查询的次数比较少,可以 \(O(\sqrt{n})\) 解决

所以可以用值域分块代替树状数组,可以做到 \(O(n\sqrt{m})\) 的复杂度

代码

#include<cstdio>
#include<cmath>
#include<cstring>
#include<algorithm>
#include<iostream>
#define rg register
inline int read(){
rg int x=0,fh=1;
rg char ch=getchar();
while(ch<'0' || ch>'9'){
if(ch=='-') fh=-1;
ch=getchar();
}
while(ch>='0' && ch<='9'){
x=(x<<1)+(x<<3)+(ch^48);
ch=getchar();
}
return x*fh;
}
const int maxn=1e6+5;
int n,m,a[maxn],blo,ans1[maxn],ans2[maxn],nans1,nans2,mmax,shuyu[maxn],cntcol[maxn],cntnum[maxn],cnt[maxn],lmax[maxn],rmax[maxn];
struct jie{
int l,r,jla,jlb,id;
jie(){}
jie(rg int aa,rg int bb,rg int cc,rg int dd,rg int ee){
l=aa,r=bb,jla=cc,jlb=dd,id=ee;
}
}b[maxn];
bool cmp(rg jie aa,rg jie bb){
if(shuyu[aa.l]==shuyu[bb.l]){
return shuyu[aa.l]&1?aa.r<bb.r:aa.r>bb.r;
} else {
return aa.l<bb.l;
}
}
void xg(rg int val,rg int op){
if(cnt[val]==0) cntcol[shuyu[val]]++;
cnt[val]+=op;
cntnum[shuyu[val]]+=op;
if(cnt[val]==0) cntcol[shuyu[val]]--;
}
void cx(rg int nl,rg int nr){
nans1=0,nans2=0;
for(rg int i=nl;i<=std::min(nr,rmax[shuyu[nl]]);i++){
nans1+=cnt[i];
nans2+=(cnt[i]!=0);
}
if(shuyu[nl]==shuyu[nr]) return;
for(rg int i=nr;i>=lmax[shuyu[nr]];i--){
nans1+=cnt[i];
nans2+=(cnt[i]!=0);
}
for(rg int i=shuyu[nl]+1;i<=shuyu[nr]-1;i++){
nans1+=cntnum[i];
nans2+=cntcol[i];
}
}
int main(){
memset(lmax,0x3f,sizeof(lmax));
n=read(),m=read();
for(rg int i=1;i<=n;i++) a[i]=read();
mmax=n;
rg int aa,bb,cc,dd;
for(rg int i=1;i<=m;i++){
aa=read(),bb=read(),cc=read(),dd=read();
mmax=std::max(mmax,bb);
b[i]=jie(aa,bb,cc,dd,i);
}
blo=sqrt(mmax);
for(rg int i=1;i<=mmax;i++){
shuyu[i]=(i-1)/blo+1;
lmax[shuyu[i]]=std::min(lmax[shuyu[i]],i);
rmax[shuyu[i]]=std::max(rmax[shuyu[i]],i);
}
std::sort(b+1,b+1+m,cmp);
rg int nl=1,nr=0;
for(rg int i=1;i<=m;i++){
while(nr<b[i].r) xg(a[++nr],1);
while(nl>b[i].l) xg(a[--nl],1);
while(nr>b[i].r) xg(a[nr--],-1);
while(nl<b[i].l) xg(a[nl++],-1);
cx(b[i].jla,b[i].jlb);
ans1[b[i].id]=nans1;
ans2[b[i].id]=nans2;
}
for(rg int i=1;i<=m;i++) printf("%d %d\n",ans1[i],ans2[i]);
return 0;
}

洛谷 P4396 [AHOI2013]作业的更多相关文章

  1. bzoj 3236: 洛谷 P4396: [AHOI2013]作业 (莫队, 分块)

    题目传送门:洛谷P4396. 题意简述: 给定一个长度为\(n\)的数列.有\(m\)次询问,每次询问区间\([l,r]\)中数值在\([a,b]\)之间的数的个数,和数值在\([a,b]\)之间的不 ...

  2. 洛谷P4396 [AHOI2013]作业(树套树)

    题意 题目链接 Sol 为什么一堆分块呀..三维数点不应该是套路离线/可持久化+树套树么.. 亲测树状数组套权值线段树可过 复杂度\(O(nlog^2n)\),空间\(O(nlogn)\)(离线) # ...

  3. 洛谷 P4396 (离散化+莫队+树状数组)

    ### 洛谷P4396  题目链接 ### 题目大意: 有 n 个整数组成的数组,m 次询问,每次询问中有四个参数 l ,r,a,b .问你在[l,r] 的区间内的所有数中,值属于[a,b] 的数的个 ...

  4. 线段树分治初步学习&洛谷P5227[AHOI2013]连通图

    线段树分治 其实思想说起来是比较简单的,我们把这个题里的所有操作(比如连边删边查询balabala)全部拍到一棵线段树上,然后对着整棵树dfs一下求解答案,顺便把操作做一下,回溯的时候撤销一下即可.虽 ...

  5. 洛谷P4396 作业 [AHOI2013] 莫队

    正解:莫队 解题报告: 传送门! 天呐太久没做莫队了连板子都认不出来了,,,所以复健下做下莫队的题目QAQ 就很板子鸭,和莫队板子比好像只有一个离散化,,,?就不讲了QAQ 等下直接放代码QAQ ov ...

  6. P4396 [AHOI2013]作业 分块+莫队

    这个题正解是莫队+树状数组,但是我个人非常不喜欢树状数组这种东西,所以决定用分块来水这个题.直接在莫队维护信息的时候,维护单点同时维护块内信息就行了. 莫队就是这几行核心代码: void add(in ...

  7. 【题解】Luogu P4396 [AHOI2013]作业

    原题传送门 最快的解法好像是cdq,但窝只会莫队+线段树/树状数组的做法 题目要我们求1.在区间[l,r]中值域在[a,b]中有多少个数2.在区间[l,r]中值域在[a,b]中有多少个不同数 一眼就看 ...

  8. luogu P4396 [AHOI2013]作业

    目录 题目 思路 错误&&傻叉 代码 题目 luogu 思路 每次都是插入比之前所有数字大的数,所以之前的答案就不会改变 用fhq-treap求出原序列,然后用树状数组依次算出每个值得 ...

  9. P4396 [AHOI2013]作业

    题目链接 luogu4396 思路 唯有水题暖人心 咕了4天,今天跟着std对拍才做出来不得不说题解真的水的一批 先离散化一下 第一问差分询问,权值树状数组套一套就好了 \(nlog_{n}\) 第二 ...

随机推荐

  1. SpringBoot之自定义拦截器

    一.自定义拦截器实现步骤 1.创建拦截器类并实现HandlerInterceptor接口 2.创建SpringMVC自定义配置类,实现WebMvcConfigurer接口中addInterceptor ...

  2. es6 Object对象扩展新方法

    ES6给Object拓展了许多新的方法,如: keys(obj):获取对象的所有key形成的数组     var obj = { foo: 'bar', baz: 42 };  Object.keys ...

  3. MySQL必知必会详细总结

    一.检索数据 1.检索单个列:SELECT prod_name FROM products; 2.检索多个列:SELECT prod_id,prod_name,prod_price FROM prod ...

  4. AcWing&#160;127.&#160;任务

    题目链接 参考y神的思路QWQ 算法:贪心 对于每一个任务: \(y\) 的差异最多能使利润\(w\)浮动\(2 * 100 = 200\)元. \(x\) 差\(1\),则会使利润\(w\)浮动\( ...

  5. linux 上安装部署python

    一般在linux中使用python 需要安装pyenv 进行版本控制 因为linux6.9自带的Python是2.6的 同时很多命令都是基于2.6开发的 所以系统环境不能改 我们要开发 只能用pyen ...

  6. ORACLE启用非默认监听端口

    1.修改listener.ora文件 LISTENER_TEST =         (DESCRIPTION =                 (ADDRESS = (PROTOCOL = TCP ...

  7. screw一键生成数据库文档

    1. 简介   在项目开发和交付阶段,数据库文档是必不可少的.对于大型项目多个数据库几百甚至几千张表来说,手写数据库文档必然是耗时且痛苦的.因此需要一个插件自动生成文档.   screw提供了多种文件 ...

  8. php项目从github自动pull到服务器

    php项目github自动pull到服务器 项目名:web 一.自动触发 1.在服务器添加脚本文件:gitpull.sh #!/bin/sh cd /www/web git reset --hard ...

  9. Docker(三):Docker安装MySQL

    查找MySQL镜像 镜像仓库 https://hub.docker.com/ 下拉镜像 docker pull mysql:5.7 查看镜像 docker images 创建MySQL容器 命令式启动 ...

  10. PHPCMS V9.6.0 SQL注入漏洞分析

    0x01 此SQL注入漏洞与metinfo v6.2.0版本以下SQL盲注漏洞个人认为较为相似.且较为有趣,故在此分析并附上exp. 0x02 首先复现漏洞,环境为: PHP:5.4.45 + Apa ...