BZOJ 1012: [JSOI2008]最大数maxnumber

本文介绍了一种处理数列操作的高效算法,包括查询数列中特定部分的最大值和将新元素按特定规则插入数列。通过构建树状结构,文章详细解释了如何在大量操作中保持数据的更新和查询效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Description

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

Input

第一行两个整数,M和D,其中M表示操作的个数(M <= 200,000),D如上文中所述,满足D在longint内。接下来
M行,查询操作或者插入操作。

Output

对于每一个询问操作,输出一行。该行只有一个数,即序列中最后L个数的最大数。


题解:
建一个空树,然后记录插入的个数,依次插入值顺便记录最大值即可…


AC代码:

#pragma GCC optimize(2)
#include<bits/stdc++.h>
#include<ext/rope>
using namespace std;
using namespace __gnu_cxx;
#define pii pair<int,int>
#define mp(a,b) make_pair(a,b)
const int MAXN = 2e5+10;
const int MOD = 100003;
const int INF = 0x3f3f3f3f;
struct node{ int l,r,val; }t[MAXN<<2];
char op[MAXN]; int last,n,m,tot;
inline void pushup(int rt){
    t[rt].val=max(t[rt<<1].val,t[rt<<1|1].val);
}
void build(int rt,int l,int r){
    t[rt].l=l,t[rt].r=r;
    if(l==r){ t[rt].val=0; return; }
    int mid=(l+r)>>1;
    build(rt<<1,l,mid); build(rt<<1|1,mid+1,r);
    pushup(rt);
}
void update(int rt,int pos,int val){
    if(t[rt].l==t[rt].r){ t[rt].val+=val;return; }
    int mid=(t[rt].l+t[rt].r)>>1;
    if(pos<=mid) update(rt<<1,pos,val);
    else update(rt<<1|1,pos,val);
    pushup(rt);
}
int query(int rt,int l,int r){
    if(l<=t[rt].l && t[rt].r<=r) return t[rt].val;
    int mid=(t[rt].l+t[rt].r)>>1,res=0;
    if(l<=mid) res=max(res,query(rt<<1,l,r));
    if(r>mid) res=max(res,query(rt<<1|1,l,r));
    return res;
}
signed main(){
#ifndef ONLINE_JUDGE
    freopen("C:\\Users\\Administrator\\Desktop\\in.txt","r",stdin);
#endif // ONLINE_JUDGE
    int n,D,x; cin>>n>>D;
    build(1,1,n);
    for(int i=1;i<=n;i++){
        scanf("%s%d",op,&x);
        if(op[0]=='A'){
            ++tot; update(1,tot,(x+last)%D);
        }else if(op[0]=='Q'){
            last = query(1,tot-x+1,tot)%D;
            printf("%d\n",last);
        }
    }
    return 0;
}

资源下载链接为: https://pan.quark.cn/s/9e7ef05254f8 在网页设计中,为图片添加文字是一种常见的需求,用于增强视觉效果或传达更多信息。本文将介绍两种常用的方法:一种是将图片设置为背景并添加文字;另一种是利用<span>标签结合CSS定位来实现。 这种方法通过CSS实现,将图片设置为一个容器(通常是<div>)的背景,然后在容器中添加文字。具体步骤如下: 创建一个包含文字的<div>元素: 使用CSS设置<div>的背景图片,并调整其尺寸以匹配图片大小: 如有需要,可使用background-position属性调整图片位置,确保文字显示在合适位置。这样,文字就会显示在图片之上。 另一种方法是将文字放在<span>标签内,并通过CSS绝对定位将其放置在图片上。步骤如下: 创建一个包含图片和<span>标签的<div>: 设置<div>为相对定位,以便内部元素可以相对于它进行绝对定位: 设置<span>为绝对定位,并通过调整top和left属性来确定文字在图片上的位置: 这种方法的优点是可以精确控制文字的位置,并且可以灵活调整文字的样式,如颜色和字体大小。 两种方法各有优势,可根据实际需求选择。在实际开发中,还可以结合JavaScript或jQuery动态添加文字,实现更复杂的交互效果。通过合理运用HTML和CSS,我们可以在图片上添加文字,创造出更具吸引力的视觉效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值