zoukankan      html  css  js  c++  java
  • BZOJ 1012 最大数

    Description

    现在请求你维护一个数列,要求提供以下两种操作: 1、 查询操作。语法:Q L 功能:查询当前数列中末尾L个数中的最大的数,并输出这个数的值。限制:L不超过当前数列的长度。 2、 插入操作。语法:A n 功能:将n加上t,其中t是最近一次查询操作的答案(如果还未执行过查询操作,则t=0),并将所得结果对一个固定的常数D取模,将所得答案插入到数列的末尾。限制:n是非负整数并且在长整范围内。注意:初始时数列是空的,没有一个数。

    Input

    第一行两个整数,M和D,其中M表示操作的个数(M <= 200,000),D如上文中所述,满足(0

    Output

    对于每一个查询操作,你应该按照顺序依次输出结果,每个结果占一行。

    Sample Input

    5 100
    A 96
    Q 1
    A 97
    Q 1
    Q 2

    Sample Output

    96
    93
    96

    HINT

     

    Source

    额,不知道怎么形容这道题。树状数组5min再见吧!!!

     1 #include<cstring>
     2 #include<cstdio>
     3 #include<iostream>
     4 #include<cstdlib>
     5 using namespace std;
     6 
     7 #define maxn 200010
     8 #define inf (1<<30)
     9 int tree[maxn],d,ans,n,m;
    10 
    11 inline int lowbit(int a) {return a & (-a);}
    12 
    13 inline void modify(int a,int b)
    14 {
    15     while (a <= m)
    16     {
    17         tree[a] = max(tree[a],b);
    18         a += lowbit(a);
    19     }    
    20 }
    21 
    22 inline int find(int a)
    23 {
    24     int ret = -inf;
    25     for (;a;a -= lowbit(a)) ret = max(ret,tree[a]);
    26     return ret;
    27 }
    28 
    29 int main()
    30 {
    31     freopen("1012.in","r",stdin);
    32     freopen("1012.out","w",stdout);
    33     scanf("%d %d
    ",&m,&d); int i;
    34     memset(tree,128,sizeof(tree));
    35     for (i = 1;i <= m;++i)
    36     {
    37         char opt; int a;scanf("%c %d
    ",&opt,&a);
    38         if (opt == 'Q')
    39         {
    40             ans = find(m-n+a);
    41             printf("%d
    ",ans);
    42         }
    43         else
    44         {
    45             a = a % d + ans % d;
    46             a %= d;
    47             ++n;
    48             modify(m-n+1,a);
    49         }
    50     }
    51     fclose(stdin); fclose(stdout);
    52     return 0;
    53 }
    View Code
  • 相关阅读:
    O(1)时间求出栈内元素最小值
    静态查找>顺序、折半、分块查找
    字符串的最大重复数
    数据结构>栈
    排序>归并排序
    动态查找>二叉查找树(Binary Search Tree)
    数据结构>图的存储结构
    数据结构>图的连通性和最小生成树
    图片的轮廓
    数据结构>队列
  • 原文地址:https://www.cnblogs.com/mmlz/p/4226141.html
Copyright © 2011-2022 走看看