普通莫队概念

莫队:莫涛队长发明的算法,尊称莫队。其实就是优化的暴力。

普通莫队只兹磁询问不支持修改,是离线的。

莫队的基本思想:就是假定我得到了一个询问区间[l,r]的答案,那么我可以在极短(通常是O(1))的时间复杂度内得到[l+1,r]的答案——于是对于区间查询类的题目,我可以一次性读完所有询问之后来回转移,得到每一个区间的答案。

如果可以通过区间[l,r]快速转移到[l-1,r][l+1,r][l,r-1][l,r+1],那么可以用O(x*|l1-l2|+|r1-r2|)的时间完成转移,[l2,r2]是[l1,r1]的后一次询问,x是[l,r]转到相邻区间的复杂度,我们让这个值最小,就是求曼哈顿距离最小生成树,但是这个比较难求。可以用分块加上一定规则来排序,以左端点所在块的编号为第一关键字排序,右端点的值作为第二关键字排序,最坏复杂度和上面的曼哈顿距离最小生成树是一样的,这个样子做的复杂度是 $O(n \sqrt n) $(不会证,反正使用分块后复杂度就是这)。

在这里,分块的作用就是加速而已。

题目

小B有一个序列,包含N个1~K之间的整数。他一共有M个询问,每个询问给定一个区间[L..R],求Sigma(c(i)^2)的值,其中i的值从1到K,其中c(i)表示数字i在[L..R]中的重复次数

分析:

无修改莫队模板题,用一个数组记录当前区间每种数字出现的次数,在莫队转移是进行维护。

先读入所有的查询并排序,然后完成指针跳转得到每次查询的结果,最后根据查询顺序排序并输出结果。

对查询排序有两种方法:

  • 左端点所在块的编号为第一关键字排序,右端点的值作为第二关键字排序
  • 左端点所在块的编号为第一关键字排序,块号相同时,如果块序号为奇就升序排r,否则降序
#include<bits/stdc++.h>
using namespace std; typedef long long ll;
const int maxn = + ;
struct Que{
int l, r, id; //id表示是第几次询问
ll res; //当前询问的答案
}q[maxn]; int n, m, k;
ll block[maxn], num[maxn], sum[maxn], size;
ll ans;
//block: 分块数组 size分块大小
//sum[i]: 元素i的个数 void init()
{
size = (int)sqrt(n);
for(int i = ;i <= n;i++) block[i] = (i-) / size + ;
} //莫队精髓一
bool cmp(Que x, Que y)
{
return block[x.l] == block[y.l] ? x.r < y.r : x.l < y.l;
} bool cmpp(Que x, Que y)//第二种排序方式,快一些
{
return (block[x.l] ^ block[y.l]) ? block[x.l] < block[y.l] : ((block[x.l] & ) ? x.r < y.r : x.r > y.r);
} //按查询顺序排序,用于输出答案
bool cmp_id(Que x, Que y)
{
return x.id < y.id;
} //莫队精髓二:转移
void modify(int x, int w)
{
ans -= sum[num[x]] * sum[num[x]]; ///先将这个位置数的原来sum的平方减去
sum[num[x]] += w; //更新个数统计数组
ans += sum[num[x]] * sum[num[x]]; //然后加上新的sum
} void solve()
{
int l = , r = ; //莫队精髓三:两个小指针来回跳,表示当前ans维护的区间的左右端点
for(int i = ;i <= m;i++)
{
while(r < q[i].r) modify(r+, ), r++;
while(r > q[i].r) modify(r, -), r--;
while(l < q[i].l) modify(l, -), l++;
while(l > q[i].l) modify(l-, ), l--;
q[i].res = ans;
}
} int main()
{
scanf("%d%d%d", &n, &m, &k);
for(int i = ;i <= n;i++) scanf("%lld", &num[i]);
for(int i = ;i <= m;i++)
{
scanf("%d%d", &q[i].l, &q[i].r);
q[i].id = i;
} init();
sort(q+, q+m+, cmp); //or cmpp solve(); sort(q+, q+m+, cmp_id);
for(int i = ;i <= m;i++)
printf("%lld\n", q[i].res); return ;
}

参考链接:

1. https://www.luogu.org/problemnew/solution/P2709?page=2

2. https://www.luogu.org/problemnew/solution/P1494

P2709 小B的询问——普通莫队&&模板的更多相关文章

  1. P2709 小B的询问(莫队)

    P2709 小B的询问 莫队模板 资磁离线询问 维护两个跳来跳去的指针 先分块,蓝后询问按块排序. 蓝后每次指针左右横跳更新答案 #include<iostream> #include&l ...

  2. 【Luogu P2709 小B的询问】莫队

    题目描述 小B有一个序列,包含N个1~K之间的整数.他一共有M个询问,每个询问给定一个区间[L..R],求Sigma(c(i)^2)的值,其中i的值从1到K,其中c(i)表示数字i在[L..R]中的重 ...

  3. P2709 小B的询问(莫队入门)

    题目链接:https://www.luogu.org/problemnew/show/P2709 题目大意:中文题目 具体思路:莫队入门题,按照离线的方式打的,对每一个区间进行分块和编号,如果在同一个 ...

  4. 洛谷 P2709 小B的询问(莫队)

    题目链接:https://www.luogu.com.cn/problem/P2709 这道题是模板莫队,然后$i$在$[l,r]$区间内的个数就是$vis[ ]$数组 $add()$和$del()$ ...

  5. 【Luogu】P2709小B的询问(莫队算法)

    题目链接 md,1A率等于0. 烦死. 终于搞到一道莫队了qwq. 先对区间分块再按照块编号为第一关键字,右端点为第二关键字排序,然后每次端点移动1乱搞. 然后……就wa了. 然后有很多细节需要注意q ...

  6. 【洛谷2709】小B的询问(莫队模板题)

    点此看题面 大致题意: 有一个长度为\(N\)的序列,每个数字在\(1\sim K\)之间,有\(M\)个询问,每个询问给你一个区间,让你求出\(\sum_{i=1}^K c(i)^2\),其中\(c ...

  7. P2709 小B的询问 (莫队板子)

    题目描述 小B有一个序列,包含N个1~K之间的整数.他一共有M个询问,每个询问给定一个区间[L..R],求Sigma(c(i)^2)的值,其中i的值从1到K,其中c(i)表示数字i在[L..R]中的重 ...

  8. BZOJ_3781_小B的询问_莫队

    BZOJ_3781_小B的询问_莫队 Description 小B有一个序列,包含N个1~K之间的整数.他一共有M个询问,每个询问给定一个区间[L..R],求Sigma(c(i)^2)的值,其中i的值 ...

  9. 小B的询问(题解)(莫队)

    小B的询问(题解)(莫队) Junlier良心莫队 题目 luoguP2709 小B的询问 code #include<bits/stdc++.h> #define lst long lo ...

随机推荐

  1. 解决git rebase操作后推送远端分支不成功的问题

    转:解决git rebase操作后推送远端分支不成功的问题 前段时间在工作中同事在rebase时遇到一个问题来问我,今天突然想起来觉得有必要记录一下. 在我们日常工作中,经常使用git座位代码管理工具 ...

  2. IO-file-03 文件的长度

    package com.bwie.io; import java.io.File; public class FileDemo4 { /**文件字节数 * length():字节数 文件夹 0 * * ...

  3. P5441 【XR-2】伤痕

    Luogu5441 有 \(n\) 个点 ( \(n\) 为奇数 , \(n \le 99\) ) 的完全图 , 其中可以有最多 \(n\) 条无向边 , 其他都是有向边 . 如果对于某四个点不经过这 ...

  4. mybatis 的一对一关联查询association

    现在项目的列表查询数据需要查一个总数count, 如果直接写在同一个sql里面,会导致查询速度很慢, 因此,想到使用关联查询,例子如下: 附上代码: 其中遇到的坑哟: 1.association中的s ...

  5. elasticsearch进行远程访问,所面对的问题解决方案

    elasticsearch6.2进行远程访问,修改yml文件后,启动会报错: 上面四个问题解决方案如下: 问题1,问题2,问题3,解决如下: 注意: 针对第二个问题,你可能在limits.d目录中没有 ...

  6. selenium弹框元素定位-冻结界面

    有些网站上面的元素,我们鼠标放在上面,会动态弹出一些内容. 比如,百度首页的右上角,有个更多产品选项,如下图所示: 如果我们把鼠标放在上边,就会弹出下面的百度营销.音乐.图片等图标. 如果我们要用se ...

  7. fiddler笔记:filters选项卡

    Host Show only Intranet Host 只显示内网(如不带"."的主机名)的数据流. Show only Internet Host 只显示互联网(如不带&quo ...

  8. 【第一季】CH09_FPGA多路分频器设计

    [第一季]CH09_FPGA多路分频器设计 在第七节的学习中,笔者带大家通过一个入门必学的流水灯实验实现,快速掌握了VIVADO基于FPGA开发板的基本流程.考虑到很多初学者并没有掌握好Vivado ...

  9. Python 常用内置模块详解

    Python 的创始人为吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏姆为了在阿姆斯特丹打发时间,决心开发一个新的脚本解释程序,作为ABC语言的一种继承.Py ...

  10. Spring与Web框架(例如Spring MVC)漫谈——关于Spring对于多个Web框架的支持

    在看Spring MVC的官方文档时,最后一章是关于Spring对于其它Web框架的支持(如JSF,Apache Struts 2.x,Tapestry 5.x),当然Spring自己的MVC框架Sp ...