传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=1208

以后在空间限制允许的情况下我绝对不纠结内存占用问题啦!就因为不舍得用long long而用unsigned,爆掉了我好几个小时。

#include <cstdio>

const int maxn = 80005, delta[2] = {-1, 1}, mod = 1000000;

int n, t1, t2, s, ans;
int ch[maxn][2], fa[maxn], root, cnt = 2;
long long key[maxn], smaller, larger; inline void rotate(int x) {
int y = fa[x];
if (y == ch[fa[y]][0]) {
ch[fa[y]][0] = x;
}
else {
ch[fa[y]][1] = x;
}
fa[x] = fa[y];
int dir = x == ch[y][1];
ch[y][dir] = ch[x][dir ^ 1];
fa[ch[x][dir ^ 1]] = y;
ch[x][dir ^ 1] = y;
fa[y] = x;
}
inline void splay(int x) {
int p;
while (fa[x]) {
p = fa[x];
if (!fa[p]) {
rotate(x);
}
else {
if ((p == ch[fa[p]][1]) ^ (x == ch[p][1])) {
rotate(x);
}
else {
rotate(p);
}
rotate(x);
}
}
root = x;
}
inline void ist(int x, long long val) {
int p = 0, dir = 0;
while (x) {
p = x;
dir = val > key[x];
x = ch[x][dir];
}
++cnt;
ch[p][dir] = cnt;
fa[cnt] = p;
key[cnt] = val;
splay(cnt);
}
inline void del(long long val) {
int x = root;
while (key[x] != val) {
if (val < key[x]) {
x = ch[x][0];
}
else {
x = ch[x][1];
}
}
splay(x);
//注意:此题splay完这个x后,x绝对有两个孩子。
fa[ch[x][0]] = fa[ch[x][1]] = 0;
int i;
for (i = ch[x][0]; ch[i][1]; i = ch[i][1]);
splay(i);
ch[i][1] = ch[x][1];
fa[ch[x][1]] = i;
}
inline long long dayudengyu(long long val) {
int x = root;
long long rt = 0;
while (x && key[x] != val) {
if (val < key[x]) {
rt = key[x];
x = ch[x][0];
}
else {
x = ch[x][1];
}
}
return x? val: rt;
}
inline long long xiaoyu(long long val) {
int x = root;
long long rt = 0;
while (x) {
if (val <= key[x]) {
x = ch[x][0];
}
else {
rt = key[x];
x = ch[x][1];
}
}
return rt;
} int main(void) {
//freopen("in.txt", "r", stdin);
scanf("%d", &n);
key[1] = -999999999999999LL;
ch[1][1] = 2;
key[2] = 999999999999999LL;
fa[2] = 1;
root = 1;
while (n--) {
scanf("%d%d", &t1, &t2);
if (!s) {
ist(root, t2);
}
else {
if (t1 ^ (s < 0)) {
ist(root, t2);
}
else {
larger = dayudengyu(t2);
smaller = xiaoyu(t2);
if (larger - (long long)t2 < (long long)t2 - smaller) {
ans = (ans + ((larger - (long long)t2) % mod)) % mod;
del(larger);
}
else {
ans = (ans + (((long long)t2 - smaller) % mod)) % mod;
del(smaller);
}
}
}
s += delta[t1];
}
printf("%d\n", ans);
return 0;
}

  

最新文章

  1. PHP 发送与接收流文件
  2. OAF_架构MVC系列4 - Control的概述(概念)
  3. Oracle中创建视图
  4. 何谓IOC的核心思想
  5. Set &lt;STL&gt;
  6. Android有效的治疗方法Bitmap,减少内存
  7. unity下跨平台excel读写
  8. topjui中combobox使用
  9. CentOS7 安装VNC
  10. eclipse中maven项目jar包不会自动下载解决办法
  11. Topic路由模式
  12. 音视频编解码: YUV采样格式中的YUV444,YUV422,YUV420理解
  13. Unity3D学习笔记第一课
  14. winform解析json
  15. cv2 与 matplotlib 的 Bug 记录
  16. C# ?? 运算符是什么?
  17. Linux服务器---配置apache支持php
  18. [BZOJ5139][Usaco2017 Dec]Greedy Gift Takers 权值线段树
  19. phper必知必会之类库自动加载的七种方式(三)
  20. 线性表 (单链表、循环链表-python实现)

热门文章

  1. CentOS 7下安装Logstash ELK Stack 日志管理系统(下)
  2. [RxJS] Implement RxJS `mergeMap` through inner Observables to Subscribe and Pass Values Through
  3. 3 Angular 2 快速上手启动项目Demo
  4. 浅谈JavaScript的字符串的replace方法
  5. HDU1251 统计难题 【trie树】
  6. (2)MyEclipse怎么关联本地Tomcat服务器
  7. Windows 异步IO操作
  8. CentOS 7.2 源码安装Python3.6
  9. bzoj3272: Zgg吃东西&amp;&amp;3267: KC采花
  10. YTU 1020: I think it