1862: [Zjoi2006]GameZ游戏排名系统

Time Limit: 5 Sec  Memory Limit: 64 MB
Submit: 1318  Solved: 498
[Submit][Status][Discuss]

Description

GameZ为他们最新推出的游戏开通了一个网站。世界各地的玩家都可以将自己的游戏得分上传到网站上。这样就可以看到自己在世界上的排名。得分越高,排名就越靠前。当两个玩家的名次相同时,先上传记录者优先。由于新游戏的火爆,网站服务器已经难堪重负。为此GameZ雇用了你来帮他们重新开发一套新的核心。排名系统通常要应付三种请求:上传一条新的得分记录、查询某个玩家的当前排名以及返回某个区段内的排名记录。当某个玩家上传自己最新的得分记录时,他原有的得分记录会被删除。为了减轻服务器负担,在返回某个区段内的排名记录时,最多返回10条记录。

Input

第一行是一个整数n(n>=10)表示请求总数目。接下来n行每行包含了一个请求。请求的具体格式如下: +Name Score 上传最新得分记录。Name表示玩家名字,由大写英文字母组成,不超过10个字符。Score为最多8位的正整数。 ?Name 查询玩家排名。该玩家的得分记录必定已经在前面上传。 ?Index 返回自第Index名开始的最多10名玩家名字。Index必定合法,即不小于1,也不大于当前有记录的玩家总数。输入文件总大小不超过2M。 NOTE:用C++的fstream读大规模数据的效率较低

Output

对于每条查询请求,输出相应结果。对于?Name格式的请求,应输出一个整数表示该玩家当前的排名。对于?Index格式的请求,应在一行中依次输出从第Index名开始的最多10名玩家姓名,用一个空格分隔。

Sample Input

20
+ADAM 1000000 加入ADAM的得分记录
+BOB 1000000 加入BOB的得分记录
+TOM 2000000 加入TOM的得分记录
+CATHY 10000000 加入CATHY的得分记录
?TOM 输出TOM目前排名
?1 目前有记录的玩家总数为4,因此应输出第1名到第4名。
+DAM 100000 加入DAM的得分记录
+BOB 1200000 更新BOB的得分记录
+ADAM 900000 更新ADAM的得分记录(即使比原来的差)
+FRANK 12340000 加入FRANK的得分记录
+LEO 9000000 加入LEO的得分记录
+KAINE 9000000 加入KAINE的得分记录
+GRACE 8000000 加入GRACE的得分记录
+WALT 9000000 加入WALT的得分记录
+SANDY 8000000 加入SANDY的得分记录
+MICK 9000000 加入MICK的得分记录
+JACK 7320000 加入JACK的得分记录
?2 目前有记录的玩家总数为12,因此应输出第2名到第11名。
?5 输出第5名到第13名。
?KAINE 输出KAINE的排名

Sample Output

2
CATHY TOM ADAM BOB
CATHY LEO KAINE WALT MICK GRACE SANDY JACK TOM BOB
WALT MICK GRACE SANDY JACK TOM BOB ADAM DAM

复习一下treap
因为同样v先提交排名靠前,所以需要记录时间
v小到大,tm大到小
treap操作变化的地方就是v相同时要讨论时间
插入一个人先在哈希表里找他,然后删除它在插入新的
注意这样的话是倒着排名
 
注意:
1.旋转别写错
2.拷贝字符串memcpy(tar,s,strlen(s))不是sizeof(s)........
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;
#define lc t[x].l
#define rc t[x].r
const int N=,MOD=;
int read(){
char c=getchar();int x=,f=;
while(c<''||c>''){if(c=='-')f=-; c=getchar();}
while(c>=''&&c<=''){x=x*+c-''; c=getchar();}
return x*f;
}
int v,tm;
char s[];
struct node{
int l,r,v,t,size,rnd;
char s[];
}t[N];
int sz,root;
inline void update(int x){t[x].size=t[lc].size+t[rc].size+;}
inline void rturn(int &x){
int c=lc;lc=t[c].r;t[c].r=x;
t[c].size=t[x].size;update(x);x=c;
}
inline void lturn(int &x){
int c=rc;rc=t[c].l;t[c].l=x;
t[c].size=t[x].size;update(x);x=c;
}
inline void ins(int &x,int v,int tm,char s[]){
if(x==){
sz++;x=sz;
t[x].l=t[x].r=;t[x].size=;
t[x].v=v;t[x].rnd=rand();t[x].t=tm;
memcpy(t[x].s,s,strlen(s));
return;
}
t[x].size++;
if(v<=t[x].v){
ins(lc,v,tm,s);
if(t[lc].rnd<t[x].rnd) rturn(x);
}else{
ins(rc,v,tm,s);
if(t[rc].rnd<t[x].rnd) lturn(x);
}
}
inline void del(int &x,int v,int tm){
if(x==) return;
if(t[x].v==v){
if(t[x].t==tm){
if(lc*rc==) x=lc+rc;
else if(t[lc].rnd<t[rc].rnd) rturn(x),del(x,v,tm);
else lturn(x),del(x,v,tm);
}else{
t[x].size--;
if(tm>t[x].t) del(lc,v,tm);
else del(rc,v,tm);
}
}else{
t[x].size--;
if(v<t[x].v) del(lc,v,tm);
else del(rc,v,tm);
}
}
int rnk(int x,int v,int tm){
if(x==) return ;
if(t[x].v==v){
if(tm==t[x].t) return t[lc].size+;
else if(tm>t[x].t) return rnk(lc,v,tm);
else return t[lc].size++rnk(rc,v,tm);
}
else if(v<t[x].v) return rnk(lc,v,tm);
else return t[lc].size++rnk(rc,v,tm);
}
int kth(int x,int k){
if(x==) return ;
if(k<=t[lc].size) return kth(lc,k);
else if(k>t[lc].size+) return kth(rc,k-t[lc].size-);
else return x;
} struct data{
int v,tm,ne;
char s[];
}mp[MOD+];
int h[MOD+],cnt;
int hsh(char s[]){
int x=,len=strlen(s+);
for(int i=;i<=len;i++) x=(x*+s[i]-'A'+)%MOD;
return x;
}
inline bool equ(char s1[],char s2[]){
int l1=strlen(s1),l2=strlen(s2);
if(l1!=l2) return false;
for(int i=;i<=l1;i++) if(s1[i]!=s2[i]) return false;
return true;
}
void Insert(char s[],int v,int tm){
int k=hsh(s);
for(int i=h[k];i;i=mp[i].ne){
if(equ(s,mp[i].s)){
del(root,mp[i].v,mp[i].tm);
mp[i].v=v;mp[i].tm=tm;
ins(root,v,tm,s);
return;
}
}
cnt++;
mp[cnt].v=v;mp[cnt].tm=tm;
memcpy(mp[cnt].s,s,strlen(s));
mp[cnt].ne=h[k];h[k]=cnt;
ins(root,v,tm,s);
}
void Rank(char s[]){
int k=hsh(s),i;
for(i=h[k];i;i=mp[i].ne)
if(equ(s,mp[i].s)) break;
printf("%d\n",cnt+-rnk(root,mp[i].v,mp[i].tm));
}
void Kth(char s[]){
int k=,len=strlen(s+);
for(int i=;i<=len;i++) k=k*+s[i]-'';
//printf("Kth %d %s %d\n",k,s,len);
for(int i=k;i<=cnt&&i<=k+;i++){
printf("%s",t[kth(root,cnt+-i)].s+);
if(i<cnt&&i<k+) putchar(' ');
}
putchar('\n');
}
int main(){
int T=read();
for(int i=;i<=T;i++){
scanf("%s",s);
if(s[]=='+'){
v=read();
Insert(s,v,i);
}else{
if(s[]>=''&&s[]<='') Kth(s);
else Rank(s);
}
}
}
 

BZOJ 1862: [Zjoi2006]GameZ游戏排名系统 [treap hash]的更多相关文章

  1. bzoj 1862: [Zjoi2006]GameZ游戏排名系统 & bzoj 1056: [HAOI2008]排名系统

    傻叉了一晚上,把t打成x,然后这题神奇在于输出一段数,不足的不用输出,一开始我的是直接找没有后面就退,然后这样会格式错误囧……然后最后zj的还卡了下空间,于是不用string就过了……string毁一 ...

  2. 【BZOJ】1862: [Zjoi2006]GameZ游戏排名系统 & 1056: [HAOI2008]排名系统(treap+非常小心)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1862 http://www.lydsy.com/JudgeOnline/problem.php?id ...

  3. bzoj 1056 [HAOI2008]排名系统(1862 [Zjoi2006]GameZ游戏排名系统)

    1056: [HAOI2008]排名系统 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1854  Solved: 502[Submit][Statu ...

  4. 1056/1862. [ZJOI2006]GameZ游戏排名系统【平衡树-splay】

    Description GameZ为他们最新推出的游戏开通了一个网站.世界各地的玩家都可以将自己的游戏得分上传到网站上.这样就可以看到自己在世界上的排名.得分越高,排名就越靠前.当两个玩家的名次相同时 ...

  5. bzoj1056/1862 [Zjoi2006]GameZ游戏排名系统

    题目链接:1,2 treap恶心题,不多说 #include<algorithm> #include<iostream> #include<cstdlib> #in ...

  6. bzoj1056: [HAOI2008]排名系统 && 1862: [Zjoi2006]GameZ游戏排名系统

    hash 加上 平衡树(名次树). 这道题麻烦的地方就在于输入的是一个名字,所以需要hash. 这个hash用的是向后探查避免冲突,如果用类似前向星的方式避免冲突,比较难写,容易挂掉,但也速度快些. ...

  7. BZOJ_1862_[Zjoi2006]GameZ游戏排名系统&&BZOJ_1056_[HAOI2008]排名系统_Splay

    BZOJ_1862_[Zjoi2006]GameZ游戏排名系统&&BZOJ_1056_[HAOI2008]排名系统_Splay Description 排名系统通常要应付三种请求:上传 ...

  8. bzoj1862: [Zjoi2006]GameZ游戏排名系统

    Description GameZ为他们最新推出的游戏开通了一个网站.世界各地的玩家都可以将自己的游戏得分上传到网站上.这样就可以看到自己在世界上的排名.得分越高,排名就越靠前.当两个玩家的名次相同时 ...

  9. [ZJOI2006]GameZ游戏排名系统

    Description GameZ为他们最新推出的游戏开通了一个网站.世界各地的玩家都可以将自己的游戏得分上传到网站上.这样就可以看到自己在世界上的排名.得分越高,排名就越靠前.当两个玩家的名次相同时 ...

随机推荐

  1. The Java Enum: A Singleton Pattern [reproduced]

    The singleton pattern restricts the instantiation of a class to one object. In Java, to enforce this ...

  2. Asp.Net Core 项目实战之权限管理系统(7) 组织机构、角色、用户权限

    0 Asp.Net Core 项目实战之权限管理系统(0) 无中生有 1 Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端 2 Asp.Net Core 项目实战之 ...

  3. 如何实现一个php框架系列文章【3】支持psr4的自动加载类

    psr4自动加载规范https://github.com/PizzaLiu/PHP-FIG/blob/master/PSR-4-autoloader-cn.md 我们把第三方使用psr规范的类库放在v ...

  4. 2015年软件测试STATE报告

    STATE OF TESTING 2015 Report 测试职业的地理位置分配 大部分有5年以上工作经验 大部分是Test Leader   测试工程师角色   测试工程师怎么工作的? 测试中的软件 ...

  5. php静态缓存简单制作

    制作缓存的目的是为了让我们的页面运行更加快速,减少读取数据库内容的次数,给用户更好的体验,为此我们可以使自己的程序做一下缓存,并且设置一个缓存过期的时间,来保证与数据库的一致,当然并不是所有的程序都适 ...

  6. 窗体作为控件嵌入panel

    EyeView frm = new EyeView(); frm.TopLevel = false; frm.Parent = this.panel1; frm.FormBorderStyle = F ...

  7. 关于XHR对象中status范围的记录

    if(xhr.status >= 200 && xhr.status < 300 || xhr.status == 304){ // 成功执行区域 // 2XX表示有效响应 ...

  8. Linux Standards Base LSB

    LSB简介 http://www.ibm.com/developerworks/cn/linux/l-lsb-intr/ http://refspecs.linuxbase.org/ http://t ...

  9. web移动端开发技巧与注意事项汇总

    一.meta的使用 1.<meta name="viewport" content="width=device-width,initial-scale=1.0, m ...

  10. centos6环境下搭建irc服务器

    问题描述 有时候逛技术社区,经常会发现有个叫IRC的东西存在,想搭建下看看到底是个什么东西 说明: 操作系统环境为CentOS6.5_64 安装irc服务器 通过yum进行安装,命令如下: yum i ...