P1198 [JSOI2008]最大数(线段树)

题目描述

现在请求你维护一个数列,要求提供以下两种操作:

1、 查询操作。

语法:Q L

功能:查询当前数列中末尾L个数中的最大的数,并输出这个数的值。

限制:L不超过当前数列的长度。(L>=0)

2、 插入操作。

语法:A n

功能:将n加上t,其中t是最近一次查询操作的答案(如果还未执行过查询操作,则t=0),并将所得结果对一个固定的常数D取模,将所得答案插入到数列的末尾。

限制:n是整数(可能为负数)并且在长整范围内。

注意:初始时数列是空的,没有一个数。

输入输出格式

输入格式:

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

接下来的M行,每行一个字符串,描述一个具体的操作。语法如上文所述。

输出格式:

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

输入输出样例

输入样例#1: 复制

5 100
A 96
Q 1
A 97
Q 1
Q 2
输出样例#1: 复制

96
93
96

说明

[JSOI2008]

本题数据已加强

分析解答:

这个题目线段树,树状数组,单调栈,分块等方法都可以做;

核心是查找一串数中的最大值。

下面是线段树的解法:

这道题并不需要提前建树,只要按照输入的顺序挨个添加就好啦

要是不会线段树的话,可以先去看一下线段树模板1

运用线段树的算法。首先建树,把所有的节点的值赋成min_int。用[i,j]表示该区间的最大值。

1)读入Q L操作。用len表示区间的大小,在len+1的位置放入(L+T)%D的值。

2)读入A n操作。输出区间[len-n+1,len]这个区间中的最大值,并把t的值进行更新。

得分:100

时间复杂度:O(nlogn)

空间复杂度:O(4*n)

next数组把所有叶子节点的位置都找到了

 #include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
struct tree
{
int l,r,_max;//左右边界和最大值
}a[];//4倍空间
int n,m,d,x,t,next[];
//建树
void make_tree(int x,int l,int r)
{
a[x].l=l;
a[x].r=r;
//叶子节点
if(l==r)
{
//这里x是root
//next里面记录的是所有叶子节点的位置,或者说编号
next[l]=x;
return;
//这里本来是要做数据的初始化的,但是因为现在数据还没加进来,做不了
}
int mid=(l+r)/;
//左右子树
make_tree(x*,l,mid);
make_tree(x*+,mid+,r);
}
void add(int x)
{
a[next[++n]]._max=(x+t)%d;//这一步就是做叶子节点数据的初始化
//本来n是0,第一个数是8的位置,那就插到8的位置就好
int temp=next[n];
//节点发生改变,肯定要更新父亲节点
//比如说第一个节点的位置是8,那么temp就是从8 4 2 1,这样一直更新到root节点
while(a[temp]._max>a[temp/]._max)//子节点大于父亲节点才更新
{
//无论是左右孩子,除2都可以得到父亲
a[temp/]._max=a[temp]._max;
temp=temp/;
}
}
//查询操作 ,这里的x是根节点 ,y是左边界 ,y是我们要查询的边界的左边界
int q(int x,int y)
{
//包含的情况,因为求最后几个,右边界是固定的
if(a[x].l>=y) return a[x]._max;
//没有相交的情况
if(a[x].r<y) return ;
//相交又不包含的情况
//左右孩子中的大值
return max(q(x*,y),q(x*+,y));
}
void print(int m){
cout<<"i"<<" "<<"next[i]"<<" "<<endl;
for(int i=;i<=*m;i++){
cout<<i<<" "<<next[i]<<" "<<endl;
}
}
int main()
{
// freopen("in.txt","r",stdin);
cin>>m>>d;
a[].l=;
a[].r=m;
//这里就是左+右除2
make_tree(,,(m+)/);
make_tree(,(m+)/+,m);
// print(m);
for(int i=;i<=m;i++)
{
char ch;
cin>>ch;
cin>>x;
//插入操作
if(ch=='A') add(x);
if(ch=='Q')
{
//查询操作,比如x是2,比如5个操作,因为进行了两次插入操作,所以n就是2,q(1,2-2+1)
//这里的1是root,而n-x+1是我们要查询的左边界,因为右边界不用管
t=q(,n-x+);
cout<<t<<endl;
}
}
// print(m);
}

P1198 [JSOI2008]最大数(线段树)的更多相关文章

  1. [JSOI2008]最大数 (线段树)

    题目描述 现在请求你维护一个数列,要求提供以下两种操作: 1. 查询操作. 语法:Q L 功能:查询当前数列中末尾L个数中的最大的数,并输出这个数的值. 限制:L不超过当前数列的长度.(L>=0 ...

  2. [JSOI2008]最大数 线段树解法

    题目描述 现在请求你维护一个数列,要求提供以下两种操作: 1. 查询操作. 语法:Q L 功能:查询当前数列中末尾L个数中的最大的数,并输出这个数的值. 限制:L不超过当前数列的长度. 2. 插入操作 ...

  3. BZOJ1012 [JSOI2008]最大数 线段树

    题目描述 现在请求你维护一个数列,要求提供以下两种操作: 1. 查询操作. 语法:Q L 功能:查询当前数列中末尾L个数中的最大的数,并输出这个数的值. 限制:LLL不超过当前数列的长度.(L> ...

  4. P1198 [JSOI2008]最大数【树状数组】

    题目描述 现在请求你维护一个数列,要求提供以下两种操作: 1. 查询操作. 语法:Q L 功能:查询当前数列中末尾L个数中的最大的数,并输出这个数的值. 限制: L 不超过当前数列的长度. (L &g ...

  5. P1198 [JSOI2008]最大数(线段树基础)

    P1198 [JSOI2008]最大数 题目描述 现在请求你维护一个数列,要求提供以下两种操作: 1. 查询操作. 语法:Q L 功能:查询当前数列中末尾L个数中的最大的数,并输出这个数的值. 限制: ...

  6. 「线段树」「单点修改」洛谷P1198 [JSOI2008]最大数

    「线段树」「单点修改」洛谷P1198 [JSOI2008]最大数 题面描述 现在请求你维护一个数列,要求提供以下两种操作: 1. 查询操作. 语法:Q L 功能:查询当前数列中末尾L个数中的最大的数, ...

  7. 洛谷P1198 [JSOI2008]最大数

    P1198 [JSOI2008]最大数 267通过 1.2K提交 题目提供者该用户不存在 标签线段树各省省选 难度提高+/省选- 提交该题 讨论 题解 记录 最新讨论 WA80的戳这QwQ BZOJ都 ...

  8. 洛谷 P1198 [JSOI2008]最大数

    洛谷 P1198 [JSOI2008]最大数 题目描述 现在请求你维护一个数列,要求提供以下两种操作: 1. 查询操作. 语法:Q L 功能:查询当前数列中末尾L个数中的最大的数,并输出这个数的值. ...

  9. 洛谷P1198 [JSOI2008]最大数(单点修改,区间查询)

    洛谷P1198 [JSOI2008]最大数 简单的线段树单点问题. 问题:读入A和Q时,按照读入一个字符会MLE,换成读入字符串就可以了. #include<bits/stdc++.h> ...

随机推荐

  1. 20181225模拟赛 T1 color (转化思想,分拆思想)

    题目: 有⼀块有 n 段的栅栏,要求第 i 段栅栏最终被刷成颜色 ci .每⼀次可以选择 l, r 把第l . . . r 都刷成某种颜色,后刷的颜⾊会覆盖之前的.⼀共有 m 种颜色,雇主知道只需要用 ...

  2. 对拍 bat命令快速模板

    对拍.bat @echo off :loop maker.exe > in.in wq.exe < in.in > out.out std.exe < in.in >st ...

  3. Bootstrap 12 栅格系统

    栅格系统简介 Bootstrap 提供了一套响应式.移动设备优先的流式栅格系统,随着屏幕或视口(viewport)尺寸的增加,系统会自动分为最多 12 列.它包含了易于使用的预定义类,还有强大的mix ...

  4. linux性能优化cpu-01性能指标

    学习性能优化的第一步,一定要了解性能指标. 性能指标是什么? 当我们看到性能指标时一定先想到“高并发”.“响应快”,这个两个指标也对应着性能优化的两个核心指标—— “吞吐率”和“低延迟”. 这两个指标 ...

  5. C#基础学习(一)

    ---恢复内容开始--- 1.最近被安排去做C#开发,然后开始一连串的看文档·看视屏,发现学C#给自己补了很多基础,C#每个函数变量什么都要先声名,而python可以直接定义: 一.数据类型 1.整数 ...

  6. 3.2.11 行 vs 字符串

        了解行(line)与字符串(string)的差异是相当重要的.大部分简易程序都是处理输入数据的行,像 grep 与 egrep,以及 sed 大部分的工作(99%)都是这样.在这些情况下,不会 ...

  7. Jackson入门

    Jackson 框架,轻易转换JSON Jackson可以轻松的将Java对象转换成json对象和xml文档,同样也可以将json.xml转换成Java对象. 前面有介绍过json-lib这个框架,在 ...

  8. shit layui & select & re-render & bug

    shit layui https://www.layui.com/doc/modules/form.html#onselect https://www.layui.com/doc/element/fo ...

  9. CSU 1225 最长上升子序列并记录其个数

    ;j<i;j++){ if(h[i] > h[j]){ ) cnt[i]+=cnt[j]; ) len[i] = len[j] + , cnt[i] = cnt[j]; } //身高相同的 ...

  10. MySQL:记录的增删改查、单表查询、约束条件、多表查询、连表、子查询、pymysql模块、MySQL内置功能

    数据操作 插入数据(记录): 用insert: 补充:插入查询结果: insert into 表名(字段1,字段2,...字段n) select (字段1,字段2,...字段n) where ...; ...