正解:莫队/分块

解题报告:

传送门

ummm这题耗了我一天差不多然后我到现在还没做完:D

而同机房的大佬用了一个小时没有就切了?大概这就是大佬和弱鸡的差距趴QAQ

然后只是大概写下思想好了因为代码我还没打出来QAQ

先说莫队?

莫队似乎有俩方式能过呢

首先是个暴力,就只对l1r1排序让l2r2乱跳,然后神仙hl过去了?然后我就过不去?委屈:D

然后可以前缀和优化一波,这个大概是最稳的,然后文佬的博客似乎写了qwq有时间再研究下趴QAQ大概思路知道一下就成立就是个二维前缀和的玩意儿qwq

然后说分块

ummm分块这个还,挺神仙的qwq,我研究了下那个代码但还没有很清楚QAQ先把写了点儿注释的放上来QAQ

#include<bits/stdc++.h>
using namespace std;

typedef long long LL;
;
;

int n,m,tmp,q,B;
struct Block{ int a[N],b[M],c; }b[M];//b[i]:这个块内部第i个元素是啥 a[i]:包括这个块,data=i的数出现了几遍 c:这个块有多大
int bl[N],a[N],t1[N],t2[N],t3[N],t4[N];
LL f[M][M];

inline int in()
{
    ;;
    '))ch=getchar();
    ;
    )+(x<<)+(ch^'),ch=getchar();
    return y?x:-x;
}
]) ;else return bl[x]; }
]) ;else return bl[x]; }
LL work(int l1,int r1,int l2,int r2)
{
    ;
    ];
    //大端内部处理
    ,c2=;
    if(bl[l1] != bl[r1])
    {
        for(int i=l1;bl[i]<L1;i++) t1[++c1]=a[i],t2[a[i]]++;
        ;i<=r1;i++) t1[++c1]=a[i],t2[a[i]]++;
    }
    ]==bl[l1] || bl[r1]==bl[r1+]) for(int i=l1;i<=r1;i++) t1[++c1]=a[i],t2[a[i]]++;
    //朴素countl1r1的小端
    if(bl[l2]!=bl[r2])
    {
        for(int i=l2;bl[i]<L2;i++) t3[++c2]=a[i],t4[a[i]]++;
        ;i<=r2;i++) t3[++c2]=a[i],t4[a[i]]++;
    }
    ]==bl[l2] || bl[r2]==bl[r2+]) for(int i=l2;i<=r2;i++) t3[++c2]=a[i],t4[a[i]]++;
    //朴素countl2r2的小端
    ;i<=c1;i++) res+=(L2<=R2 ? b[R2].a[t1[i]]-b[L2-].a[t1[i]] : ) + t4[t1[i]];
    //朴素把l1r1小端的处理辽,用大端+小端
    ;i<=c2;i++) res+=b[R1].a[t3[i]]-b[L1-].a[t3[i]];
    //朴素处理小端
    ;i<=c1;i++) t2[t1[i]]--;
    ;i<=c2;i++) t4[t3[i]]--;
    //清零
    return res;
}
int main()
{
    n=,B=sqrt(n)+;
    ;i<=n;i++)
    {
        if(b[m].c >= B) ++m;
        a[i]=in(),bl[i]=m,b[m].b[++b[m].c]=a[i];
    }
    ;i<=m;i++)
    {
        ;j<=n;j++) b[i].a[j]=b[i-].a[j];
        ;j<=b[i].c;j++) b[i].a[b[i].b[j]]++;
    }
    ;i<=m;i++) ;j<=m;j++) ;k<=b[i].c;k++) f[i][j]+=b[j].a[b[i].b[k]];//第i个块到第j个块的ans
    for(q=in();q--;)
    {
        int l1=in(),r1=in(),l2=in(),r2=in();
        cout<<work(l1,r1,l2,r2)<<endl;
    };
}

这儿,是,代码QAQ

先这样不想刚这题了,over

CFGym101138D Strange Queries 莫队/分块的更多相关文章

  1. Bzoj 3236: [Ahoi2013]作业 莫队,分块

    3236: [Ahoi2013]作业 Time Limit: 100 Sec  Memory Limit: 512 MBSubmit: 1113  Solved: 428[Submit][Status ...

  2. [BZOJ 3585] mex 【莫队+分块】

    题目链接:BZOJ - 3585 题目分析 区间mex,即区间中没有出现的最小自然数. 那么我们使用一种莫队+分块的做法,使用莫队维护当前区间的每个数字的出现次数. 然后求mex用分块,将权值分块(显 ...

  3. BZOJ_3585_mex && BZOJ_3339_Rmq Problem_莫队+分块

    BZOJ_3585_mex && BZOJ_3339_Rmq Problem_莫队+分块 Description 有一个长度为n的数组{a1,a2,...,an}.m次询问,每次询问一 ...

  4. BZOJ_3809_Gty的二逼妹子序列 && BZOJ_3236_[Ahoi2013]作业 _莫队+分块

    BZOJ_3809_Gty的二逼妹子序列 && BZOJ_3236_[Ahoi2013]作业 _莫队+分块 Description Autumn和Bakser又在研究Gty的妹子序列了 ...

  5. BZOJ3236[Ahoi2013]作业——莫队+树状数组/莫队+分块

    题目描述 输入 输出 样例输入 3 4 1 2 2 1 2 1 3 1 2 1 1 1 3 1 3 2 3 2 3 样例输出 2 2 1 1 3 2 2 1 提示 N=100000,M=1000000 ...

  6. [BZOJ3585]mex(莫队+分块)

    显然可以离线主席树,这里用莫队+分块做.分块的一个重要思想是实现修改与查询时间复杂度的均衡,这里莫队和分块互相弥补. 考虑暴力的分块做法,首先显然大于n的数直接忽略,于是将值域分成sqrt(n)份,每 ...

  7. 小Z的袜子(莫队分块)题解

    小Z的袜子(hose) 作为一个生活散漫的人,小Z每天早上都要耗费很久从一堆五颜六色的袜子中找出一双来穿.终于有一天,小Z再也无法忍受这恼人的找袜子过程,于是他决定听天由命……具体来说,小Z把这N只袜 ...

  8. 【CodeForces】700 D. Huffman Coding on Segment 哈夫曼树+莫队+分块

    [题目]D. Huffman Coding on Segment [题意]给定n个数字,m次询问区间[l,r]的数字的哈夫曼编码总长.1<=n,m,ai<=10^5. [算法]哈夫曼树+莫 ...

  9. 莫队+分块 BZOJ 3809

    3809: Gty的二逼妹子序列 Time Limit: 80 Sec  Memory Limit: 28 MBSubmit: 1634  Solved: 482[Submit][Status][Di ...

随机推荐

  1. 分析轮子(一)-ArrayList.java

    前言:之前也看过一些JDK源码,不过没有留下痕迹,经久年月就淡忘了,现在的时机也差不多了,想再看一次,并且记录下来自己的感想,于是从自己使用最多最熟悉的地方开始!并且看的过程中,我希望自己思考一下如下 ...

  2. Linux内核剖析(四)为arm内核构建源码树

    前面说到要做linux底层开发或者编写Linux的驱动,必须建立内核源码树,之前我们提到过在本机上构建源码树—-Linux内核剖析(三),其建立的源码树是针对i686平台的,但是我么嵌入式系统用的是a ...

  3. Python源码中的PyCodeObject

    1.Python程序的执行过程 Python解释器(interpreter)在执行任何一个Python程序文件时,首先进行的动作都是先对文件中的Python源代码进行编译,编译的主要结果是产生的一组P ...

  4. Atitti 互联网时代三大竞争战略 ——平台化战略 锚”战略、价值领先战略

    Atitti 互联网时代三大竞争战略 ——平台化战略 锚”战略.价值领先战略 美国著名管理学家迈克尔•波特在<竞争战略>一书中提出了集中化战略和差异化战略.成本领先战略三种基本竞争战略,从 ...

  5. Navicat(数据库可视化操作软件)安装、配置、测试

    Navicat(数据库可视化操作软件)安装.配置.测试(win7_64bit) 目录 1.概述 2.本文用到的工具 3.Navicat安装.激活与配置 4.简单测试 5.注意事项 6.相关博文 > ...

  6. Nginx SSL 结合Tomcat 重定向URL变成HTTP的问题

    http://www.siven.net/posts/d925bb5d.html *********************************************** 问题描述 由于要配置服 ...

  7. re.S、 re.M

    re.S是代表.可以匹配\n以及“  re.M是多行   code import re a = '''asdfsafhellopass: 234455 worldafdsf ''' b = re.fi ...

  8. session_id()和session_regenerate_id()对原来session文件和其中数据是怎么处理的

    一.session_id()对原来session文件和里面的数据,是怎么处理的? 测验办法:<?php $sid = md5("aaad");session_id($sid) ...

  9. C语言 · 求先序遍历

    算法训练 求先序排列   时间限制:1.0s   内存限制:256.0MB        锦囊1 后序的最后一个字母为根结点.   问题描述 给出一棵二叉树的中序与后序排列.求出它的先序排列.(约定树 ...

  10. RabbitMQ内存爆出

    RabbitMQ升级到3.6.1版本后,随着业务和系统功能的增加,出现RabbitMQ内存陡增直至服务宕掉的情况.内存增加时,在management管理控制台上可以见到如下警告: The manage ...