Description

最近,阿Q开了一间宠物收养所。收养所提供两种服务:收养被主人遗弃的宠物和让新的主人领养这些宠物。每个领养者都希望领养到自己满意的宠物,阿Q根据领养者的要求通过他自己发明的一个特殊的公式,得出该领养者希望领养的宠物的特点值a(a是一个正整数,a<2^31),而他也给每个处在收养所的宠物一个特点值。这样他就能够很方便的处理整个领养宠物的过程了,宠物收养所总是会有两种情况发生:被遗弃的宠物过多或者是想要收养宠物的人太多,而宠物太少。 1. 被遗弃的宠物过多时,假若到来一个领养者,这个领养者希望领养的宠物的特点值为a,那么它将会领养一只目前未被领养的宠物中特点值最接近a的一只宠物。(任何两只宠物的特点值都不可能是相同的,任何两个领养者的希望领养宠物的特点值也不可能是一样的)如果有两只满足要求的宠物,即存在两只宠物他们的特点值分别为a-b和a+b,那么领养者将会领养特点值为a-b的那只宠物。 2. 收养宠物的人过多,假若到来一只被收养的宠物,那么哪个领养者能够领养它呢?能够领养它的领养者,是那个希望被领养宠物的特点值最接近该宠物特点值的领养者,如果该宠物的特点值为a,存在两个领养者他们希望领养宠物的特点值分别为a-b和a+b,那么特点值为a-b的那个领养者将成功领养该宠物。 一个领养者领养了一个特点值为a的宠物,而它本身希望领养的宠物的特点值为b,那么这个领养者的不满意程度为abs(a-b)。【任务描述】你得到了一年当中,领养者和被收养宠物到来收养所的情况,希望你计算所有收养了宠物的领养者的不满意程度的总和。这一年初始时,收养所里面既没有宠物,也没有领养者。

Input

第一行为一个正整数n,n<=80000,表示一年当中来到收养所的宠物和领养者的总数。接下来的n行,按到来时间的先后顺序描述了一年当中来到收养所的宠物和领养者的情况。每行有两个正整数a, b,其中a=0表示宠物,a=1表示领养者,b表示宠物的特点值或是领养者希望领养宠物的特点值。(同一时间呆在收养所中的,要么全是宠物,要么全是领养者,这些宠物和领养者的个数不会超过10000个)

Output

仅有一个正整数,表示一年当中所有收养了宠物的领养者的不满意程度的总和mod 1000000以后的结果。

Sample Input


Sample Output


(abs(3-2) + abs(2-4)=3,最后一个领养者没有宠物可以领养)

Solution

用平衡树求前驱后缀

1、可以用set简单实现

#pragma __attribute__((optimize("-O2")))
#include <set>
#include <stdio.h>
#include <algorithm>
#define oo 1e9
#define mo 1000000
#define ST std::set<int>
template<typename Type> inline void Rin(register Type &x)
{
int c=getchar();
for(x=0;c<48||c>57;c=getchar());
for(;c>47&&c<58;x=(x<<1)+(x<<3)+c-48,c=getchar());
}
int n,ans,a,b,c,l,r; ST sit; ST::iterator it;
int main()
{
sit.insert(oo),sit.insert(-oo),Rin(n);
for(;n;n--)
{
Rin(a),Rin(b);
if(sit.size()==2||a==c)sit.insert(b),c=a;
else
{
it=sit.lower_bound(b),r=*it-b,l=b-*(--it);
if(l<=r)(ans+=l)%=mo,sit.erase(it);
else (ans+=r)%=mo,sit.erase(++it);
}
}
printf("%d\n",ans);
return 0;
}

  

2、可以用手码treap

#include <time.h>
#include <stdio.h>
#include <stdlib.h>
#define mo 1000000
#define dabs(x) ((x)<(0)?(-x):(x))
template<class Type> inline void read(register Type &x)
{
int c=getchar();
for(x=0;c<48||c>57;c=getchar());
for(;c>47&&c<58;x=(x<<1)+(x<<3)+c-48,c=getchar());
}
struct Node
{
Node *ch[2];
int val,rend;
Node(int _val):val(_val)
{rend=rand(),ch[0]=ch[1]=NULL;}
int Comp(int _)const
{return (_==val)?(-1):(val<_);}
}*root;
inline void Rotate(Node *&o,int d)
{
Node *k=o->ch[d^1];
o->ch[d^1]=k->ch[d];
k->ch[d]=o;
o=k;
}
void GetPre(Node *o,int _val,int &tmp)
{
if(o==NULL)return;
if(_val>=o->val)tmp=o->val,GetPre(o->ch[1],_val,tmp);
else GetPre(o->ch[0],_val,tmp);
}
void GetNext(Node *o,int _val,int &tmp)
{
if(o==NULL)return;
if(_val<=o->val)tmp=o->val,GetNext(o->ch[0],_val,tmp);
else GetNext(o->ch[1],_val,tmp);
}
void Insert(Node *&o,int _val)
{
if(o==NULL)
{o=new Node(_val);return;}
int d=o->Comp(_val);
if(!~d)return;
Insert(o->ch[d],_val);
if(o->ch[d]->rend > o->rend)Rotate(o,d^1);
}
void Erase(Node *&o,int _val)
{
if(o==NULL)return;
int d=o->Comp(_val);
if(~d)Erase(o->ch[d],_val);
else
{
Node *u=o;
if(o->ch[0]!=NULL&&o->ch[1]!=NULL)
{
d=o->ch[0]->rend > o->ch[1]->rend;
Rotate(o,d);
Erase(o->ch[d],_val);
}
else
{
if(o->ch[0]!=NULL)o=o->ch[0];
else o=o->ch[1];
delete u;
}
}
}
int n,ans;
int main()
{
read(n);
for(int a,b,c;n;n--)
{
read(a),read(b);
if(root==NULL)
root=new Node(b),c=a;
else if(c==a) Insert(root,b);
else
{
int l=-1,r=-1;
GetPre(root,b,l),GetNext(root,b,r);
if(!~l)(ans+=dabs(r-b))%=mo,Erase(root,r);
else if(!~r)(ans+=dabs(b-l))%=mo,Erase(root,l);
else
{
if(dabs(b-l)<=dabs(r-b))(ans+=dabs(b-l))%=mo,Erase(root,l);
else (ans+=dabs(r-b))%=mo,Erase(root,r);
}
}
}
printf("%d\n",ans);
return 0;
}

  

[bzoj1208][HNOI2004][宠物收养所] (平衡树)的更多相关文章

  1. BZOJ1208 HNOI2004 宠物收养所 【非旋转Treap】

    BZOJ1208 HNOI2004 宠物收养所 Description 最近,阿Q开了一间宠物收养所.收养所提供两种服务:收养被主人遗弃的宠物和让新的主人领养这些宠物.每个领养者都希望领养到自己满意的 ...

  2. bzoj1208 [HNOI2004]宠物收养所(STL,Treap)

    1208: [HNOI2004]宠物收养所 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 5956  Solved: 2317[Submit][Sta ...

  3. 2018.07.06 BZOJ1208: HNOI2004宠物收养所(非旋treap)

    1208: [HNOI2004]宠物收养所 Time Limit: 10 Sec Memory Limit: 162 MB Description 最近,阿Q开了一间宠物收养所.收养所提供两种服务:收 ...

  4. Bzoj1208 [HNOI2004]宠物收养所

    Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 7457  Solved: 2960 Description 最近,阿Q开了一间宠物收养所.收养所提供两 ...

  5. BZOJ1208[HNOI2004]宠物收养场——treap

    凡凡开了一间宠物收养场.收养场提供两种服务:收养被主人遗弃的宠物和让新的主人领养这些宠物. 每个领养者都希望领养到自己满意的宠物,凡凡根据领养者的要求通过他自己发明的一个特殊的公式,得出该领养者希望领 ...

  6. [bzoj1208][HNOI2004]宠物收养所——splay

    题目大意 Description 最近,阿Q开了一间宠物收养所.收养所提供两种服务:收养被主人遗弃的宠物和让新的主人领养这些宠物.每个领养者都希望领养到自己满意的宠物,阿Q根据领养者的要求通过他自己发 ...

  7. B1208 [HNOI2004]宠物收养所 平衡树||set (滑稽)

    这个题是一道splay裸题,但是我不太会写,所以用set直接水过去!!!哈哈哈哈,美滋滋. set总结: set是一个集合,然后里面没用重复的元素.里面有一些函数: begin()     ,返回se ...

  8. 【set】【Splay】【pb_ds】bzoj1208 [HNOI2004]宠物收养所

    每次来的如果是人,且宠物数不为零,就从宠物中选出一个与其差距最小的,累加答案:若为零,就把他放入另一个集合里. 如果是宠物,则同上. 各种平衡树都可过,我蛋疼地用了pb_ds. Code: #incl ...

  9. BZOJ1208 [HNOI2004]宠物收养所 splay

    原文链接http://www.cnblogs.com/zhouzhendong/p/8085803.html 题目传送门 - BZOJ1208 题意概括 有两种数,依次加入. 规则为下: 如果当前剩余 ...

随机推荐

  1. python代码覆盖率coverage简介与用法

    如果衡量单元测试对相应代码的测试重量,覆盖率是一个必要非充分条件,因此统计代码的覆盖率,检视单测是否充分,就尤为的重要.这里针对python-unittest的单测的覆盖率coverage进行使用说明 ...

  2. nginx 配置tp3.2

    server { listen 80; server_name 域名; #charset koi8-r; #access_log /var/log/nginx/host.access.log main ...

  3. _bzoj2038 [2009国家集训队]小Z的袜子(hose)【莫队】

    传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=2038 裸的莫队,注意要先移动右端点再移动左端点. #include <cstdio&g ...

  4. 51nod 1138 连续整数的和

    1138 连续整数的和  基准时间限制:1 秒 空间限制:131072 KB 分值: 10 难度:2级算法题  收藏  关注 给出一个正整数N,将N写为若干个连续数字和的形式(长度 >= 2). ...

  5. 洛谷 P2312 解方程

    题目 首先,可以确定的是这题的做法就是暴力枚举x,然后去计算方程左边与右边是否相等. 但是noip的D2T3怎么会真的这么简单呢?卡常卡的真是熟练 你需要一些优化方法. 首先可以用秦九韶公式优化一下方 ...

  6. 水题 Codeforces Round #307 (Div. 2) A. GukiZ and Contest

    题目传送门 /* 水题:开个结构体,rk记录排名,相同的值有相同的排名 */ #include <cstdio> #include <cstring> #include < ...

  7. Drawable(6)关于StateList的补充

    模板: <?xml version="1.0" encoding="utf-8"?> <selector xmlns:android=&quo ...

  8. Android Dialogs(5)[正常显示dlg,将Fragment显示为dialog,将Aty显示为dlg,嵌入],关闭Dialog

    Showing a Dialog When you want to show your dialog, create an instance of your DialogFragment and ca ...

  9. 微信官方UI库—WeUI

    WeUI 为微信 Web 服务量身设计 概述 WeUI是一套同微信原生视觉体验一致的基础样式库,由微信官方设计团队为微信 Web 开发量身设计,可以令用户的使用感知更加统一.包含button.cell ...

  10. orcale 数据库的一些知识

    最近学了一些Oracle数据库的知识,我想自己整理一下,以后也方便自己查阅的. orcale 数据库登录(tiger) 1. sql plus 登录 用户名: sys 口令: 主机字符串:orcl a ...