题解 P1198 【[JSOI2008]最大数】
说起来这还是蒟蒻AC的第一道省选线段树呢。
这道题和其他线段树最大的不同就是在于本题数组一直在增大。
寻常的线段树蒟蒻习惯用如下的结构体储存,然而对于此题就不行了:
- struct node{
- int l, r;
- int val;
- } tree[maxn << ];
这是因为这道题没有用建树,因此l, r就不存在啊!
那么解决方法就是用朴实的tree数组储存val, l和r则手动传入函数!!
所以根据这个原理,稍微修改一下模板就可以得出全新的两个函数!!
- void Update(ll l, ll r, ll index, ll value, ll pos) {
- if(l == r) {
- tree[pos] = value;
- return ;
- }
- ll mid = (l + r) >> ;
- if(mid >= index) Update(l, mid, index, value, pos << );
- if(mid < index) Update(mid + , r, index, value, pos << | );
- tree[pos] = max(tree[pos << ], tree[pos << | ]);
- }
- ll Query(ll L, ll R, ll l, ll r, ll pos) {
- if(L >= l && R <= r) return tree[pos];
- ll mid = (L + R) >> ;
- ll ans = ;
- if(mid >= l) ans = max(ans, Query(L, mid, l, r, pos << ));
- if(mid < r) ans = max(ans, Query(mid + , R, l, r, pos << | ));
- return ans;
- }
注明:第二个函数中,L,R表示当前区间,l,r表示寻找的区间。
完整AC代码献上:
- #include <iostream>
- #include <cstdio>
- #include <algorithm>
- using namespace std;
- typedef long long ll;
- const int maxn = ;
- ll tree[maxn << ];
- ll m, d, t = , len = , x;
- char op;
- void Update(ll l, ll r, ll index, ll value, ll pos) {
- if(l == r) {
- tree[pos] = value;
- return ;
- }
- ll mid = (l + r) >> ;
- if(mid >= index) Update(l, mid, index, value, pos << );
- if(mid < index) Update(mid + , r, index, value, pos << | );
- tree[pos] = max(tree[pos << ], tree[pos << | ]);
- }
- ll Query(ll L, ll R, ll l, ll r, ll pos) {
- if(L >= l && R <= r) return tree[pos];
- ll mid = (L + R) >> ;
- ll ans = ;
- if(mid >= l) ans = max(ans, Query(L, mid, l, r, pos << ));
- if(mid < r) ans = max(ans, Query(mid + , R, l, r, pos << | ));
- return ans;
- }
- int main() {
- cin >> m >> d;
- for(ll i = ; i < m; i++){
- cin >> op >> x;
- if(op == 'Q') {
- if(x == ) {
- t = ;
- cout << t << endl;
- } else {
- t = Query(, m, len - x + , len, );
- cout << t << endl;
- }
- } else {
- len++;
- Update(, m, len, (x + t) % d, );
- }
- }
- }
本代码1776ms, 氧化后1276ms。
比较玄学的一件事就是用cin过了,用scanf和快读却TLE了。【滑稽】
题解 P1198 【[JSOI2008]最大数】的更多相关文章
- 洛谷P1198 [JSOI2008]最大数
P1198 [JSOI2008]最大数 267通过 1.2K提交 题目提供者该用户不存在 标签线段树各省省选 难度提高+/省选- 提交该题 讨论 题解 记录 最新讨论 WA80的戳这QwQ BZOJ都 ...
- 洛谷 P1198 [JSOI2008]最大数
洛谷 P1198 [JSOI2008]最大数 题目描述 现在请求你维护一个数列,要求提供以下两种操作: 1. 查询操作. 语法:Q L 功能:查询当前数列中末尾L个数中的最大的数,并输出这个数的值. ...
- 【题解】[JSOI2008]最大数
[题解][P1198 JSOI2008]最大数 正难则反,意想不到. 这道题是动态让你维护一个数列,已经在数列里面的数据不做改变,每次在最后加上一个数,强制在线. 既然正着做很难,考虑如果时间倒流,不 ...
- P1198 [JSOI2008]最大数(线段树基础)
P1198 [JSOI2008]最大数 题目描述 现在请求你维护一个数列,要求提供以下两种操作: 1. 查询操作. 语法:Q L 功能:查询当前数列中末尾L个数中的最大的数,并输出这个数的值. 限制: ...
- P1198 [JSOI2008]最大数(单调栈)
P1198 [JSOI2008]最大数 题目描述 现在请求你维护一个数列,要求提供以下两种操作: 1. 查询操作. 语法:Q L 功能:查询当前数列中末尾L个数中的最大的数,并输出这个数的值. 限制: ...
- P1198 [JSOI2008]最大数(线段树)
P1198 [JSOI2008]最大数(线段树) 题目描述 现在请求你维护一个数列,要求提供以下两种操作: 1. 查询操作. 语法:Q L 功能:查询当前数列中末尾L个数中的最大的数,并输出这个数的值 ...
- 洛谷P1198 [JSOI2008]最大数(单点修改,区间查询)
洛谷P1198 [JSOI2008]最大数 简单的线段树单点问题. 问题:读入A和Q时,按照读入一个字符会MLE,换成读入字符串就可以了. #include<bits/stdc++.h> ...
- 「线段树」「单点修改」洛谷P1198 [JSOI2008]最大数
「线段树」「单点修改」洛谷P1198 [JSOI2008]最大数 题面描述 现在请求你维护一个数列,要求提供以下两种操作: 1. 查询操作. 语法:Q L 功能:查询当前数列中末尾L个数中的最大的数, ...
- 【题解】洛谷P1198 [JSOI2008] 最大数(线段树)
洛谷P1198:https://www.luogu.org/problemnew/show/P1198 思路 一道水水的线段树 20分钟A掉 这道题只涉及到单点修改和区间查询 所以这道题甚至不用Laz ...
- 洛谷P1198 [JSOI2008]最大数(BZOJ.1012 )
To 洛谷.1198 最大数 题目描述 现在请求你维护一个数列,要求提供以下两种操作: 1. 查询操作. 语法:Q L 功能:查询当前数列中末尾L个数中的最大的数,并输出这个数的值. 限制:L不超过当 ...
随机推荐
- ACM-ICPC 2018 徐州赛区网络预赛 H. Ryuji doesn't want to study(树状数组)
Output For each question, output one line with one integer represent the answer. 样例输入 5 3 1 2 3 4 5 ...
- 视图层 view
视图层是 Django 处理请求的核心代码层,我们大多数 Python 代码都集中在这一层面.它对外接收用户请求,对内调度模型层和模版层,统合数据库和前端,最后根据业务逻辑,将处理好的数据,与前端结合 ...
- 联想lenovo 家用电脑安装win7 无法引导问题(新电脑安装系统时提示File:\Boot\BCD错误解决方案)
安装方式 : 1.进入 PE 2.用 EasyimageX 恢复 GHO镜像 3.重启后出现 原因: 主要 是安装win7 时,格式 化选择为GUID模式. 处理: win7 以后,格式华时选择MB ...
- requests 常见方法总结
请求设置:requests.get/post ( url, data={}, params={}, headers={}, timeout=0.01, files={} Session() ...
- How Javascript works (Javascript工作原理) (六) WebAssembly 对比 JavaScript 及其使用场景
个人总结: 1.webassembly简介:WebAssembly是一种用于开发网络应用的高效,底层的字节码.允许在网络应用中使用除JavaScript的语言以外的语言(比如C,C++,Rust及其他 ...
- BZOJ 3166 [HEOI2013]Alo (可持久化01Trie+链表)
题目大意:给你一个长度为$n$的序列,让你找出一段子序列,求其中的 次大值 异或 序列里一个数 能得到的最大值 先对序列建出可持久化$Trie$ 按元素的值从小到大遍历,设当前元素的位置是i,找出它左 ...
- maven 安装jar包
1 下载maven: 下载路径: http://mirrors.hust.edu.cn/apache/maven/maven-3/3.5.0/binaries/apache-maven-3.5.0-b ...
- 【Paper Reading】Object Recognition from Scale-Invariant Features
Paper: Object Recognition from Scale-Invariant Features Sorce: http://www.cs.ubc.ca/~lowe/papers/icc ...
- 队列(Queue)-c实现
相对而言,队列是比较简单的. 代码还有些warning,我改不动,要找gz帮忙. #include <stdio.h> typedef struct node { int data; st ...
- c进程学习日志
#include<unistd.h> #include<sys/types.h> #include<pwd.h> #include<stdio.h> i ...