BZOJ 3236: [Ahoi2013]作业( 莫队 + BIT )

时间:2023-02-22 09:22:04

BZOJ 3236: [Ahoi2013]作业( 莫队 + BIT )

莫队..用两个树状数组计算.时间复杂度应该是O(N1.5logN). 估计我是写残了...跑得很慢...

-------------------------------------------------------------------------

#include<bits/stdc++.h>
 
using namespace std;
 
#define lowbit(x) ((x) & -(x))
 
const int maxn = 100009;
const int maxm = 1000009;
 
int N, M, block[maxn], seq[maxn], ans[maxm][2], L, R;
 
inline int read() {
int ans = 0;
char c = getchar();
for(; !isdigit(c); c = getchar());
for(; isdigit(c); c = getchar())
   ans = ans * 10 + c - '0';
return ans;
}
 
int buf[12];
inline void write(int x) {
if(!x) {
putchar('0');
return;
}
int n = 0;
for(; x; x /= 10) buf[n++] = x % 10;
while(n--) putchar(buf[n] + '0');
}
 
struct BIT {
int b[maxn];
BIT() {
memset(b, 0, sizeof b);
}
inline void update(int x, int v) {
for(; x <= N; x += lowbit(x)) b[x] += v;
}
inline int sum(int x) {
int ret = 0;
for(; x; x -= lowbit(x)) ret += b[x];
return ret;
}
inline int query(int l, int r) {
return sum(r) - sum(l - 1);
}
} cnt, exist;
 
struct Q {
int l, r, a, b, p;
inline void Read(int t) {
l = read() - 1; r = read() - 1;
a = read(); b = read();
p = t;
}
bool operator < (const Q &o) const {
return block[l] < block[o.l] || (block[l] == block[o.l] && r < o.r);
}
} A[maxm];
 
void init() {
N = read(); M = read();
for(int i = 0; i < N; i++) seq[i] = read();
int blocks = (int) sqrt(N);
for(int i = 0; i < N; i++) block[i] = i / blocks;
for(int i = 0; i < M; i++) A[i].Read(i);
}
 
void work(int x) {
Q* c = A + x;
for(; L < c->l; L++) {
cnt.update(seq[L], -1);
if(!cnt.query(seq[L], seq[L])) exist.update(seq[L], -1);
}
while(L > c->l) {
L--;
if(!cnt.query(seq[L], seq[L])) exist.update(seq[L], 1);
cnt.update(seq[L], 1);
}
for(; R > c->r; R--) {
cnt.update(seq[R], -1);
if(!cnt.query(seq[R], seq[R])) exist.update(seq[R], -1);
}
while(R < c->r) {
R++;
if(!cnt.query(seq[R], seq[R])) exist.update(seq[R], 1);
cnt.update(seq[R], 1);
}
ans[c->p][0] = cnt.query(c->a, c->b);
ans[c->p][1] = exist.query(c->a, c->b);
}
 
int main() {
init();
sort(A, A + M);
cnt.update(seq[L = R = 0], 1);
exist.update(seq[0], 1);
for(int i = 0; i < M; i++) work(i);
for(int i = 0; i < M; i++) {
write(ans[i][0]);
putchar(' ');
write(ans[i][1]);
putchar('\n');
}
return 0;
}

-------------------------------------------------------------------------

3236: [Ahoi2013]作业

Time Limit: 100 Sec  Memory Limit: 512 MB
Submit: 899  Solved: 345
[Submit][Status][Discuss]

Description

BZOJ 3236: [Ahoi2013]作业( 莫队 + BIT )

Input

BZOJ 3236: [Ahoi2013]作业( 莫队 + BIT )

Output

BZOJ 3236: [Ahoi2013]作业( 莫队 + BIT )

Sample Input

3 4
1 2 2
1 2 1 3
1 2 1 1
1 3 1 3
2 3 2 3

Sample Output

2 2
1 1
3 2
2 1

HINT

N=100000,M=1000000

Source

BZOJ 3236: [Ahoi2013]作业( 莫队 + BIT )的更多相关文章

  1. Bzoj 3236&colon; &lbrack;Ahoi2013&rsqb;作业 莫队&comma;分块

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

  2. BZOJ 3236&colon; &lbrack;Ahoi2013&rsqb;作业&lpar;莫队&plus;树状数组&rpar;

    传送门 解题思路 莫队+树状数组.把求\([a,b]\)搞成前缀和形式,剩下的比较裸吧,用\(cnt\)记一下数字出现次数.时间复杂度\(O(msqrt(n)log(n)\),莫名其妙过了. 代码 # ...

  3. BZOJ 3809&colon; Gty的二逼妹子序列 &amp&semi; 3236&colon; &lbrack;Ahoi2013&rsqb;作业 &lbrack;莫队&rsqb;

    题意: 询问区间权值在$[a,b]$范围内种类数和个数 莫队 权值分块维护种类数和个数$O(1)-O(\sqrt{N})$ #include <iostream> #include &lt ...

  4. &lbrack;AHOI2013&rsqb;作业 &lpar;莫队&plus;分块&rpar;

    [AHOI2013]作业 (莫队+分块) 题面 给定了一个长度为n的数列和若干个询问,每个询问是关于数列的区间[l,r],首先你要统计该区间内大于等于a,小于等于b的数的个数,其次是所有大于等于a,小 ...

  5. BZOJ 3236&colon; &lbrack;Ahoi2013&rsqb;作业

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

  6. bzoj 3236&colon; &lbrack;Ahoi2013&rsqb;作业(缺线段树)

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

  7. &lbrack;BZOJ 3236&rsqb; &lbrack;Ahoi2013&rsqb; 作业 &amp&semi;&amp&semi; &lbrack;BZOJ 3809&rsqb; 【莫队(&plus;分块)】

    题目链接: BZOJ - 3236   BZOJ - 3809 算法一:莫队 首先,单纯的莫队算法是很好想的,就是用普通的第一关键字为 l 所在块,第二关键字为 r 的莫队. 这样每次端点移动添加或删 ...

  8. bzoj 3236&colon; 洛谷 P4396&colon; &lbrack;AHOI2013&rsqb;作业 &lpar;莫队&comma; 分块&rpar;

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

  9. 【BZOJ3809&sol;3236】Gty的二逼妹子序列 &lbrack;Ahoi2013&rsqb;作业 莫队算法&plus;分块

    [BZOJ3809]Gty的二逼妹子序列 Description Autumn和Bakser又在研究Gty的妹子序列了!但他们遇到了一个难题. 对于一段妹子们,他们想让你帮忙求出这之内美丽度∈[a,b ...

随机推荐

  1. Linux编译源码的方式安装Qt4开发环境(基于Ubuntu系统)

    1.到官网http://qt-project.org/downloads或者ftp://ftp.qt-project.org/上下载Qt的源码包,要安装当然要先有源码咯,我下载的是qt-everywh ...

  2. UVA 11426 GCD - Extreme &lpar;II&rpar; &lpar;欧拉函数&plus;筛法&rpar;

    题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=70017#problem/O 题意是给你n,求所有gcd(i , j)的和,其中 ...

  3. SGU题目总结

    SGU还是个不错的题库...但是貌似水题也挺多的..有些题想出解法但是不想写代码, 就写在这里吧...不排除是我想简单想错了, 假如哪位神犇哪天发现请告诉我.. 101.Domino(2015.12. ...

  4. 『TensorFlow』使用集合collection控制variables

    Variable Tensorflow使用Variable类表达.更新.存储模型参数. Variable是在可变更的,具有保持性的内存句柄,存储着Tensor 在整个session运行之前,图中的全部 ...

  5. &period;NET Core开发日志——Action

    在叙述Controller一文中,有一处未做解释,即CreateControllerFactory方法中ControllerActionDescriptor参数是如何产生的.这是因为其与Action的 ...

  6. Linux rsync 命令学习

    Rsync命令和cp命令很像,但是功能似乎更加复杂点,主要用来备份数据.看了网上一堆介绍的文章,感觉不是很通俗易懂.下面按照我的理解,做一些笔记: 同步方式 之前接触过一些同步软件,例如坚果云.百度云 ...

  7. &lbrack;转&rsqb;JSON Web Token - 在Web应用间安全地传递信息

    JSON Web Token(JWT)是一个非常轻巧的规范.这个规范允许我们使用JWT在用户和服务器之间传递安全可靠的信息. 让我们来假想一下一个场景.在A用户关注了B用户的时候,系统发邮件给B用户, ...

  8. 【学习笔记】--- 老男孩学Python,day18 面向对象------继承

    继承 继承是一种创建新类的方式,在python中,新建的类可以继承一个或多个父类, 父类又可称为基类或超类,新建的类称为派生类或子类 python中类的继承分为:单继承和多继承 class Fathe ...

  9. MySQL高性能优化实战总结

    1.1 前言 MySQL对于很多Linux从业者而言,是一个非常棘手的问题,多数情况都是因为对数据库出现问题的情况和处理思路不清晰.在进行MySQL的优化之前必须要了解的就是MySQL的查询过程,很多 ...

  10. three&period;js轨道控制器OrbitControls&period;js

    https://blog.csdn.net/qq_37338983/article/details/78575333 文章地址