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. .NET Core的文件系统[1]:读取并监控文件的变化

    ASP.NET Core 具有很多针对文件读取的应用.比如我们倾向于采用JSON文件来定义配置,所以应用就会涉及针对配置文件读取.如果用户发送一个针对物理文件的HTTP请求,应用会根据指定的路径读取目 ...

  2. chrome控制台模拟hover、focus、active等状态,方便调试

    有时候需要调试一个网页,需要某些元素在hover.focus.active等状态. 比如hover,鼠标放到hover上,然后去控制台中找DOM,鼠标移开的时候元素就不是hover状态了. 此时可以使 ...

  3. ZFPlayer 源码解读

    源码下载地址:https://github.com/renzifeng/ZFPlayer 之前自己实现过一个模仿百思不得姐的demo https://github.com/agelessman/FFm ...

  4. TCP初始化序列号ISN

    TCP初始化序列号ISN TCP初始化序列号不能设置为一个固定值,因为这样容易被攻击者猜出后续序列号,从而遭到攻击. RFC1948中提出了一个较好的初始化序列号ISN随机生成算法. ISN = M ...

  5. Index

    我主要在研究.NET/C# 实现 PC IMERP 和 Android IMERP ,目的在解决企业通信中遇到的各类自动化问题   分布式缓存框架: Microsoft Velocity:微软自家分布 ...

  6. Entity Framework 教程——模型浏览器

    模型浏览器: 在之前的章节中,我们创建了第一个关于学校的实体数据模型.但是EDM设计器并没有将他所创建的所有对象完全显示出来.它只将数据库中的被选择的表与视图显示出来了. 模型浏览器可以将EDM所创建 ...

  7. Hibernate全套增删改查+分页

    1.创建一个web工程 2.导入jar包 3.创建Student表 4.创建实体类 package com.entity; public class Student { private Integer ...

  8. HTTPS和HTTP的概念和区别

    HTPPS和HTTP的概念 HTTPS(全称:Hypertext Transfer Protocol over Secure Socket Layer),是以安全为目标的HTTP通道,简单讲是HTTP ...

  9. vue2.0 非父子组件如何通信

    1 利用父组件传递 A组件传递到父组件,再由父组件传递到B组件 2 利用新的vue实例 var bus = new Vue() // 触发组件 A 中的事件 bus.$emit('id-selecte ...

  10. js 轮播效果

    <!--图片轮播      Start-->                    <div class="pics-ul">               ...