题目链接

luogu4396

思路

唯有水题暖人心

咕了4天,今天跟着std对拍才做出来不得不说题解真的水的一批

先离散化一下

第一问差分询问,权值树状数组套一套就好了 \(nlog_{n}\)

第二问,Emma

莫队,加上树状数组维护修改 \(nlog_{n}sqrt_{n}\)

\(3s\)随便过吧,最慢的也才\(800ms\)

代码

#include <bits/stdc++.h>
#define FOR(i,a,b) for(int i=a;i<=b;++i)
using namespace std;
const int maxn = 1e5 + 7;
int n, m, w[maxn];
int sub[maxn * 3], belong[maxn], lsh[maxn * 3];
struct query {
int s, t, a, b, id, ans1, ans2, tmp;
} Q[maxn];
bool cmp1(query a, query b) {return a.s < b.s;}
bool cmp2(query a, query b) {return a.t < b.t;}
bool cmp3(query a, query b) {return belong[a.t] == belong[b.t] ? a.s < b.s : a.t < b.t;}
bool cmp4(query a, query b) {return a.id < b.id;}
int read() {
int x = 0, f = 1; char s = getchar();
for (; s < '0' || s > '9'; s = getchar()) if (s == '-')f = -1;
for (; s >= '0' && s <= '9'; s = getchar()) x = x * 10 + s - '0';
return x * f;
}
int sum[maxn*6];
void add(int x, int ad) {
for (int i = x; i <= 3e5; i += (i&-i)) sum[i] += ad;
}
int query(int x) {
int ans = 0;
for (int i = x; i >= 1; i -= (i&-i)) ans += sum[i];
return ans;
}
inline void add(int x) {
if (!sub[x]) add(x, 1);
sub[x]++;
}
inline void delet(int x) {
sub[x]--;
if (!sub[x]) add(x, -1);
}
int main() {
// read
n = read(), m = read();
int k = sqrt(n);
FOR(i, 1, n) lsh[i] = w[i] = read();
FOR(i, 1, n) belong[i] = (i - 1) / k + 1;
int js = n;
FOR(i, 1, m) {
Q[i].s = read(),Q[i].t = read(),Q[i].a = read(),Q[i].b = read();
lsh[++js] = Q[i].a,lsh[++js] = Q[i].b, Q[i].id = i;
}
sort(lsh + 1, lsh + 1 + n + m * 2);
int nn = unique(lsh + 1, lsh + 1 + n + 2 * m) - (lsh + 1);
FOR(i, 1, n) w[i] = lower_bound(lsh + 1, lsh + 1 + nn, w[i]) - lsh;
FOR(i, 1, m) {
Q[i].a = lower_bound(lsh + 1, lsh + 1 + nn, Q[i].a) - lsh;
Q[i].b = lower_bound(lsh + 1, lsh + 1 + nn, Q[i].b) - lsh;
} // work1
js = 1;
sort(Q + 1, Q + 1 + m, cmp1);
FOR(i, 1, n) {
for (; Q[js].s == i; ++js)
Q[js].tmp = query(Q[js].b) - query(Q[js].a - 1);
add(w[i], 1);
} js = 1;
sort(Q + 1, Q + 1 + m, cmp2);
memset(sum, 0, sizeof(sum));
FOR(i, 1, n) {
add(w[i], 1);
for(;Q[js].t == i;++js)
Q[js].ans1 = query(Q[js].b) - query(Q[js].a - 1) - Q[js].tmp;
} // work2
sort(Q + 1, Q + 1 + m, cmp3);
memset(sum, 0, sizeof(sum));
int l = 1, r = 0;
FOR(i, 1, m) {
while (l > Q[i].s) add(w[--l]);
while (l < Q[i].s) delet(w[l++]);
while (r < Q[i].t) add(w[++r]);
while (r > Q[i].t) delet(w[r--]);
Q[i].ans2 = query(Q[i].b) - query(Q[i].a - 1);
} //print
sort(Q + 1, Q + 1 + m, cmp4);
FOR(i, 1, m) printf("%d %d\n", Q[i].ans1, Q[i].ans2);
}

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

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

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

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

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

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

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

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

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

  5. luogu P4396 [AHOI2013]作业

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

  6. 洛谷 P4396 [AHOI2013]作业

    题目描述 题目传送门 分析 因为询问是关于区间的,并且没有强制在线,所以能用莫队解决 但是还要支持查询区间内大于等于 \(a\),小于等于 \(b\) 的数的个数和数值的个数 所以还要套一个数据结构 ...

  7. [AHOI2013]作业 (莫队+分块)

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

  8. BZOJ 3236: [Ahoi2013]作业

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

  9. 树套树专题——bzoj 3110: [Zjoi2013] K大数查询 &amp; 3236 [Ahoi2013] 作业 题解

    [原题1] 3110: [Zjoi2013]K大数查询 Time Limit: 20 Sec  Memory Limit: 512 MB Submit: 978  Solved: 476 Descri ...

随机推荐

  1. Jmeter(二十一)_脚本参数化与内存溢出的解决方案

    这一篇文章随便说一下JMETER的脚本参数化 1:Parameters的两种参数化方法 1.1:函数助手参数化 首先准备你的参数数据.我在bin/data中新建了一个dat文件,记事本另存为修改编码为 ...

  2. 网站优化(SEO)的10大误区

    前段时间大前端也有关于SEO的文章贡献给广大读者,今日,再发一文,网站优化(SEO)的10大误区.很多新手站长初次接触SEO,感受到SEO 的无穷魅力,想要做一位优秀的SEOer,然而新手朋友在进行S ...

  3. 【python-opencv】对象测量

    opencv 中轮廓特征包括: 如面积,周长,质心,边界框等 *弧长与面积测量 *多边形拟合 *获取轮廓的多边形拟合结果 python-opencv API提供方法: cv2.moments()用来计 ...

  4. 【其他】csv文件打开是乱码,怎么办?

    csv文件打开是乱码,怎么办?管用的方法,一个就够 工作中,将python生成的中间结果文件写入CSV,经常这么干是不是?文件保存下来后用excel打开,出现了乱码情况,真心烦.为什么? CSV是用U ...

  5. mysql 数据类型 目录

    mysql 数据类型 mysql 整数类型 数值类型 tinyint mysql int 整数类型 解释显示宽度 和 存储宽度 mysql float 浮点型 mysql 日期类型 mysql 字符串 ...

  6. js与jQuery差别

    jQuery能大大简化Javascript程序的编写,我近期花时间了解了一下jQuery.把我上手过程中的笔记和大家分享出来.希望对大家有所帮助. 要使用jQuery.首先要在HTML代码最前面加上对 ...

  7. MySQL字符集的一个坑

    MySQL字符集的一个坑 http://imysql.com/2013/10/29/misunderstand-about-charset-handshake.shtml MySQL字符集的一个坑 1 ...

  8. MYSQL常见的可优化点

    MYSQL常见的可优化点 SQL常见的可优化点 2014年6月8日 DBA 发表回复 # #################################################### 索引 ...

  9. 解决 libev.so.4()(64bit) is needed by percona-xtrabackup-2.3.4-1.el6.x86_64案例

    在mysql主从同步时经常会用到Xtra, XtraBackup可以说是一个相对完美的免费开源数据备份工具,支持在线无锁表同步复制和可并行高效率的安全备份恢复机制相比mysqldump来说优势较大好处 ...

  10. logistics回归

    logistic回归的基本思想 logistic回归是一种分类方法,用于两分类问题.其基本思想为: a. 寻找合适的假设函数,即分类函数,用以预测输入数据的判断结果: b. 构造代价函数,即损失函数, ...