题目描述

OIER公司是一家大型专业化软件公司,有着数以万计的员工。作为一名出纳员,我的任务之一便是统计每位员工的工资。这本来是一份不错的工作,但是令人郁闷的是,我们的老板反复无常,经常调整员工的工资。如果他心情好,就可能把每位员工的工资加上一个相同的量。反之,如果心情不好,就可能把他们的工资扣除一个相同的量。我真不知道除了调工资他还做什么其它事情。
工资的频繁调整很让员工反感,尤其是集体扣除工资的时候,一旦某位员工发现自己的工资已经低于了合同规定的工资下界,他就会立刻气愤地离开公司,并且再也不会回来了。每位员工的工资下界都是统一规定的。每当一个人离开公司,我就要从电脑中把他的工资档案删去,同样,每当公司招聘了一位新员工,我就得为他新建一个工资档案。
老板经常到我这边来询问工资情况,他并不问具体某位员工的工资情况,而是问现在工资第k多的员工拿多少工资。每当这时,我就不得不对数万个员工进行一次漫长的排序,然后告诉他答案。
好了,现在你已经对我的工作了解不少了。正如你猜的那样,我想请你编一个工资统计程序。怎么样,不是很困难吧?
如果某个员工的初始工资低于最低工资标准,那么将不计入最后的答案。

分析

模拟赛的题目是这道题目的改编,成功把自己卡成40分QwQ。
其实就是一个treap的模板,在下降的时候要把整体一起下降。
I命令:加入一个员工 我们在平衡树中加入k-minn
A命令:把每位员工的工资加上k delta加k即可
S命令:把每位员工的工资扣除k 此时我们就需要考虑会不会导致一大批员工离开;我们插入minn-delta,然后使小于minn-delta的点一起移动到根的右子树的左子树,一举消灭;
最后一个命令就是直接查询kth就可以了。
代码好久之前码的,码风不大一样。

代码

# include <bits/stdc++.h>
# define N 100005
using namespace std ;
struct Treap{
    int ch[N][2] , rd[N] , sz[N] , v[N] , num[N] ;
    int root , sum , delta ;
    void maintain( int &o ) { sz[o] = sz[ch[o][0]] + sz[ch[o][1]] + 1 ; }
    void right_rotate( int &o ) {
        int lson = ch[o][0] ; ch[o][0] = ch[lson][1] ; ch[lson][1] = o ; sz[lson] = sz[o] ;
        maintain(o) ; o = lson ;
    }
    void left_rotate( int &o ) {
        int rson = ch[o][1] ; ch[o][1] = ch[rson][0] ; ch[rson][0] = o ; sz[rson] = sz[o] ;
        maintain(o) ; o = rson ;
    }
    void insert( int &o , int x ) {
        if ( o == 0 ) { sum ++ ; o = sum ; rd[o] = rand() ; num[o] = x ; sz[o] = 1 ; return ; }
        sz[o] ++ ;
        if ( x < num[o] ) { insert( ch[o][0] , x ) ; if ( rd[ch[o][0]] < rd[o] ) right_rotate(o) ; }
        else { insert( ch[o][1] , x ) ; if ( rd[ch[o][1]] < rd[o] ) left_rotate(o) ; }
    }
    int del( int &o , int x ) {
        int tmp ; if ( o == 0 ) return 0 ;
        if ( num[o] < x ) { tmp = sz[ch[o][0]] + 1 ; o = ch[o][1] ; return tmp + del( o , x ) ; }
        else { tmp = del( ch[o][0] , x ) ; sz[o] -= tmp ; return tmp ; }
    }
    int find( int o , int x ) {
        if ( sz[ch[o][0]] + 1 == x ) return num[o] + delta ;
        else if ( sz[ch[o][0]] + 1 < x ) return find( ch[o][1] , x - sz[ch[o][0]] - 1 ) ;
        else return find( ch[o][0] , x ) ;
    }
};
Treap Tp ;
int n , m , cnt ;
int main () {
    scanf( "%d%d" , &n , &m ) ;
    for ( int i = 1 ; i <= n ; i ++ ) {
        char s[10] ; int x ;
        scanf( "%s%d" , s , &x ) ;
        if ( s[0] == 'I' ) if ( x >= m ) Tp.insert( Tp.root , x - Tp.delta ) ;
        if ( s[0] == 'A' ) Tp.delta += x ;
        if ( s[0] == 'S' ) Tp.delta -= x , cnt += Tp.del( Tp.root , m - Tp.delta ) ;
        if ( s[0] == 'F' ) {
            if ( x > Tp.sz[Tp.root] ) printf( "-1\n" ) ;
            else printf( "%d\n" , Tp.find( Tp.root , Tp.sz[Tp.root] - x + 1 ) ) ;
        }
        //cout << "cnt : " << cnt << endl ;
    }
    printf( "%d\n" , cnt ) ;
    return 0 ;
}

[luogu1486][bzoj1503][NOI2004]郁闷的出纳员【平衡树treap】的更多相关文章

  1. [BZOJ1503][NOI2004]郁闷的出纳员

    [BZOJ1503][NOI2004]郁闷的出纳员 试题描述 OIER公司是一家大型专业化软件公司,有着数以万计的员工.作为一名出纳员,我的任务之一便是统计每位员工的工资.这本来是一份不错的工作,但是 ...

  2. [BZOJ1503][NOI2004]郁闷的出纳员 无旋Treap

    1503: [NOI2004]郁闷的出纳员 Time Limit: 5 Sec  Memory Limit: 64 MB Description OIER公司是一家大型专业化软件公司,有着数以万计的员 ...

  3. Luogu P1486 [NOI2004]郁闷的出纳员(平衡树)

    P1486 [NOI2004]郁闷的出纳员 题意 题目描述 \(OIER\)公司是一家大型专业化软件公司,有着数以万计的员工.作为一名出纳员,我的任务之一便是统计每位员工的工资.这本来是一份不错的工作 ...

  4. bzoj1503 [NOI2004]郁闷的出纳员(名次树+懒惰标记)

    1503: [NOI2004]郁闷的出纳员 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 8705  Solved: 3027[Submit][Statu ...

  5. bzoj1503: [NOI2004]郁闷的出纳员(伸展树)

    1503: [NOI2004]郁闷的出纳员 题目:传送门 题解: 修改操作一共不超过100 直接暴力在伸展树上修改 代码: #include<cstdio> #include<cst ...

  6. BZOJ1503[NOI2004]郁闷的出纳员——treap

    OIER公司是一家大型专业化软件公司,有着数以万计的员工.作为一名出纳员,我的任务之一便是统计每位员工的工资.这本来是一份不错的工作,但是令人郁闷的是,我们的老板反复无常,经常调整员工的工资.如果他心 ...

  7. [BZOJ1503] [NOI2004] 郁闷的出纳员 (treap)

    Description OIER公司是一家大型专业化软件公司,有着数以万计的员工.作为一名出纳员,我的任务之一便是统计每位员工的工资.这本来是一份不错的工作,但是令人郁闷的是,我们的老板反复无常,经常 ...

  8. 2018.08.06 bzoj1503: [NOI2004]郁闷的出纳员(非旋treap)

    传送门 平衡树简单题. 直接用fhgtreap实现分裂和合并就没了. 代码: #include<bits/stdc++.h> #define N 100005 using namespac ...

  9. BZOJ1503: [NOI2004]郁闷的出纳员(Splay)

    Description OIER公司是一家大型专业化软件公司,有着数以万计的员工.作为一名出纳员,我的任务之一便是统计每位员工的 工资.这本来是一份不错的工作,但是令人郁闷的是,我们的老板反复无常,经 ...

随机推荐

  1. dynamo与cassandra区别

    虽说cassandra是dynamo的开源版本,但两者还是有很大区别的. coordinator的选取: 在dynamo论文中,一般是preference list中N个副本的第一个 为什么叫“一般” ...

  2. shell脚本使用记录一:操作文件

    一,连接远程数据库(保证在服务器上能使用mysql命令行,至少要安装mysql客户端) #!/bin/bash HOSTNAME="ip" PORT=" USERNAME ...

  3. asp.net Json序列化

    Json作为一种数据传输格式与标准被广泛的使用在项目开发中,可以说简直离不开它.那么怎么来生成JSON格式的数据就成了我们首先需要解决的问题这里我们使用.net. 首先是获取数据 public ban ...

  4. 非常详细的Docker学习教程

    一.Docker 简介 Docker 两个主要部件: Docker: 开源的容器虚拟化平台 Docker Hub: 用于分享.管理 Docker 容器的 Docker SaaS 平台 -- Docke ...

  5. asp.net core下一个简单的分页技术

    在做web应用的时候免不了要对数据进行分页,我最近在做asp.net core的开发的时候就遇到了这个需求,现在简单的记录一下: public class PaginatedList<T> ...

  6. PreparedStatement 与 Statement 的区别

    1. PreparedStatement 接口继承 Statement, PreparedStatement 实例包含已编译的 SQL 语句,所以其执行速度要快于 Statement 对象. 2.作为 ...

  7. 03 测试Hadoop hdfs 上传 与 mr

    1.随便在哪个目录新增一个文档.内容随便输入 mkdir words 2.在hdfs 中新建文件输入目录 ./hdfs dfs -mkdir /test 3.把新建的文档 (/home/hadoop/ ...

  8. [转帖]Linux:cut命令详解

    Linux:cut命令详解 https://www.cnblogs.com/Spiro-K/p/6361646.html cut -f cut -f -d cut -c1- 这三个命令好像最常见, 记 ...

  9. [GS]uuid-ossp

    uuid-ossp 原贴地址:http://postgres.cn/docs/9.6/uuid-ossp.html 关于 OSSP的含义 uuid-ossp模块提供函数使用几种标准算法之一产生通用唯一 ...

  10. (C/C++)区别:数组与指针,指针与引用

    1.数组跟指针的区别 数组要么在静态存储区被创建(如全局数组),要么在栈上被创建.数组名对应着(而不是指向)一块内存,其地址与容量在生命期内保持不变,只有数组的内容可以改变. 指针可以随时指向任意类型 ...