一开始我用分块大法,分成$\sqrt{n}$块,每个块上维护一个Splay,然后balabala维护一下,时间复杂度是$O(n\sqrt{n}logn)$。后来对拍的时候发现比$O(n^2)$的暴力跑得还慢,xxy学长说是Splay常数太大2333333

考试的时候没想到可以在每个块上建一个$10^5$的数组来存储每个数字出现的次数,而是用了常数巨大且复杂度多了一个log的SplayQwQ,发现自己完全没有对空间复杂度的认识啊(┙>∧<)┙へ┻┻

标算是块状链表,什么balabala比较基础地维护,卡着空间开2333333

我把块的大小设为$[\frac{\sqrt{n}}{2},\sqrt{n}×2)$,在codevs上TLE,,,

后来把块的大小改成了$[\sqrt{n},\sqrt{n}×2)$,1s内能轻松跑过。

也许是因为某些玄学的原因吧,,,

#include<cmath>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int N = 100000;
const int B = 316;
const int BB = 632; int in() {
int k = 0, fh = 1; char c = getchar();
for(; c < '0' || c > '9'; c = getchar())
if (c == '-') fh = -1;
for(; c >= '0' && c <= '9'; c = getchar())
k = (k << 3) + (k << 1) + c - '0';
return k * fh;
} struct BLOCK {
BLOCK() {
nxt = NULL;
len = 0;
memset(times, 0, sizeof(times));
}
BLOCK *nxt;
int a[BB + B + 3], times[N + 1], len;
}; int cnt = 0;
int n; namespace BlockList {
BLOCK *head;
void Build(BLOCK * t) {head = t;}
void split(BLOCK *r) {
int rlen = r->len / 2, tlen = r->len - rlen, to = rlen;
BLOCK *t = new BLOCK;
memcpy(t->a + 1, r->a + rlen + 1, sizeof(int) * tlen);
for(int i = 1; i <= tlen; ++i) {
++t->times[t->a[i]];
--r->times[t->a[i]];
}
t->len = tlen;
r->len = rlen;
t->nxt = r->nxt;
r->nxt = t;
}
void merge(BLOCK *r) {
BLOCK *t = r->nxt;
if (t == NULL) return;
int tlen = t->len, to = r->len;
memcpy(r->a + to + 1, t->a + 1, sizeof(int) * tlen);
for(int i = 1; i <= tlen; ++i)
++r->times[t->a[i]];
r->len += tlen;
t = t->nxt;
delete r->nxt;
r->nxt = t;
if (r->len >= BB) split(r);
}
BLOCK *find(int &k) {
BLOCK *t = head;
while (k - t->len > 0 && t != NULL) {
k -= t->len;
t = t->nxt;
}
return t;
}
void work(int l, int r) {
BLOCK *t = find(r);
int num = t->a[r];
--t->times[num];
int tlen = --t->len;
for(int i = r; i <= tlen; ++i)
t->a[i] = t->a[i + 1];
if (t->len < B) merge(t);
t = find(l);
for(int i = ++t->len; i > l; --i)
t->a[i] = t->a[i - 1];
t->a[l] = num;
++t->times[num];
if (t->len >= BB) split(t);
}
int query(int l, int r, int k) {
BLOCK *tl = find(l), *tr = find(r);
int ret = 0;
if (tl == tr) {
for(int i = l; i <= r; ++i)
if (tl->a[i] == k) ++ret;
return ret;
} else {
int lentl = tl->len;
for(int i = l; i <= lentl; ++i)
if (tl->a[i] == k) ++ret;
for(int i = 1; i <= r; ++i)
if (tr->a[i] == k) ++ret;
for(tl = tl->nxt; tl != tr && tl != NULL; ret += tl->times[k], tl = tl->nxt);
return ret;
}
}
} int main() {
n = in();
int c = 0, k;
BLOCK *tmp = new BLOCK;
BlockList::Build(tmp);
for(int i = 1; i <= n; ++i) {
++c;
if (c > B) {
c = 1;
tmp->len = B;
tmp->nxt = new BLOCK;
tmp = tmp->nxt;
}
k = in();
tmp->a[c] = k;
++tmp->times[k];
}
tmp->len = c;
int m = in(), op, l, r;
while (m--) {
op = in(); l = in(); r = in();
if (op == 1)
BlockList::work(l, r);
else {
k = in();
printf("%d\n", BlockList::query(l, r, k));
}
}
return 0;
}

继续颓文化课,期末考试Bless All!

【CodeVS 5032】【省队集训2016 Day5 T1】Play with array的更多相关文章

  1. [2018湖南省队集训] 6.24 T1 marshland

    题面在这里! 一开始感觉像一个类似二分图的最小割,于是成功跑偏2333333 很容易发现一个关键性质,'L'的两个角落在的偶数格 的行(或者列)的奇偶性一定不同.... 于是我们再把偶数格按照行(或者 ...

  2. JS省队集训记

    不知不觉省队集训已经结束,离noi也越来越近了呢 论考前实战训练的重要性,让我随便总结一下这几天的考试 Day 1 T1 唉,感觉跟xj测试很像啊?meet in middle,不过这种题不多测是什么 ...

  3. HN2018省队集训

    HN2018省队集训 Day1 今天的题目来自于雅礼的高二学长\(dy0607\). 压缩包下载 密码: 27n7 流水账 震惊!穿着该校校服竟然在四大名校畅通无阻?霸主地位已定? \(7:10\)从 ...

  4. 2018HN省队集训

    HNOI2018省队集训 Day 1 流水账 T1 tree 换根+求\(lca\)+求子树和,一脸bzoj3083遥远的国度的既视感.子树和讨论一下就好了,\(lca\)?也是大力讨论一波. 先写了 ...

  5. 2017FJ省队集训 游记

    2017FJ省队集训 游记 又是一篇流水账 Day 1 今天是省队集训的第一天.早上骑车去八中,到的时候汗流太多浑身湿透被杨哥哥和runzhe2000 d了,一个说我去游泳了一个说我打球了...流完汗 ...

  6. UOJ #274. 【清华集训2016】温暖会指引我们前行 [lct]

    #274. [清华集训2016]温暖会指引我们前行 题意比较巧妙 裸lct维护最大生成树 #include <iostream> #include <cstdio> #incl ...

  7. UOJ_274_[清华集训2016]温暖会指引我们前行_LCT

    UOJ_274_[清华集训2016]温暖会指引我们前行_LCT 任务描述:http://uoj.ac/problem/274 本题中的字典序不同在于空串的字典序最大. 并且题中要求排序后字典序最大. ...

  8. UOJ 275. 【清华集训2016】组合数问题

    UOJ 275. [清华集训2016]组合数问题 组合数 $C_n^m $表示的是从 \(n\) 个物品中选出 \(m\) 个物品的方案数.举个例子,从$ (1,2,3)(1,2,3)$ 三个物品中选 ...

  9. UOJ #269. 【清华集训2016】如何优雅地求和

    UOJ #269. [清华集训2016]如何优雅地求和 题目链接 给定一个\(m\)次多项式\(f(x)\)的\(m+1\)个点值:\(f(0)\)到\(f(m)\). 然后求: \[ Q(f,n,x ...

随机推荐

  1. NYOJ-取石子(六)

    取石子(六) 时间限制:1000 ms  |  内存限制:65535 KB 难度:3 描述 最近TopCoder的PIAOYI和HRDV很无聊,于是就想了一个游戏,游戏是这样的:有n堆石子,两个人轮流 ...

  2. Codeforces 549D. Hear Features[贪心 英语]

    D. Haar Features time limit per test 1 second memory limit per test 256 megabytes input standard inp ...

  3. JSP中九大内置对象及其数据类型

    JSP中九大内置对象为: request              请求对象               类型 javax.servlet.ServletRequest         作用域 Req ...

  4. div根据内容改变大小并且左右居中

    div{ display:inline-block; width:auto; } 这个div的父元素text-align:center;

  5. java 22 - 20 多线程之线程池

    程序启动一个新线程成本是比较高的,因为它涉及到要与操作系统进行交互. 而使用线程池可以很好的提高性能,尤其是当程序中要创建大量生存期很短的线程时,更应该考虑使用线程池. 线程池里的每一个线程代码结束后 ...

  6. java 22 - 12 多线程之解决线程安全问题的实现方式1

    从上一章知道了多线程存在着线程安全问题,那么,如何解决线程安全问题呢? 导致出现问题的原因: A:是否是多线程环境 B:是否有共享数据 C:是否有多条语句操作共享数据 上一章的程序,上面那3条都具备, ...

  7. noip2013 积木大赛

    题目描述 春春幼儿园举办了一年一度的“积木大赛”.今年比赛的内容是搭建一座宽度为n的大厦,大厦可以看成由n块宽度为1的积木组成,第i块积木的最终高度需要是hi. 在搭建开始之前,没有任何积木(可以看成 ...

  8. JS中NULL和Undefined的区别

    NULL是表示一个”无“的对象,转换成数值为0:undefined是一个“无”的原始值,转为数值为NaN: 当声明的变量还未被初始化时,变量的默认值为undefined: null用来表示尚未存在的对 ...

  9. c# HttpClient禁止缓存

    using (var client = new HttpClient())             {                //方法1:                 CacheContr ...

  10. 修复ext4日志(jbd2)bug( Ext4 文件系统有以下 Bug)

    from:http://blog.donghao.org/2013/03/20/%E4%BF%AE%E5%A4%8Dext4%E6%97%A5%E5%BF%97%EF%BC%88jbd2%EF%BC% ...