codevs 3304 水果姐逛水果街Ⅰ
这道题可以用ST表过:
题目链接
记录4个数组:maxval[][], minval[][], ans[][], rans[][]
maxval[i][j]表示从i号元素开始,长度为(1<<j)(也就是2^j)的区间上的最大值
minval[i][j]表示从i号元素开始,长度为(1<<j)的区间上的最小值
ans[i][j]表示从i号元素开始,长度为(1<<j)的区间从左往右方向的答案
rans[i][j]表示从i号元素开始,长度为(1<<j)的区间从右往左方向的答案
那么易得如下转移方程:
maxval[i][j] = max(maxval[i][j - 1], maxval[i + (1 << (j - 1))][j - 1])
minval差不多
对于ans和rans的转移,我们这样考虑
区间[l, r]上的答案,要么是区间[l, (l+r)/2]上的答案,要么是区间[(l+r)/2+1, r]上的答案,要么是[(l+r)/2+1, r]上的最大值减去[l, (l+r)/2]上的最小值,以上三者中取最大者
ans[i][j] = max(ans[i][j - 1], ans[i + (1 << (j - 1))][j - 1], maxval[i + (1 << (j - 1))][j - 1] - minval[i][j - 1]);
rans差不多
在预处理的时候,要把j的循环提到外层,因为[l, r]的状态需要用到[(l+r)/2+1, r]的状态转移而来
如果j的循环在内层的话,求解[l, r]的状态时[(l+r)/2+1, r]的状态还没有求解过
查询的过程应该比较好理解,直接看代码吧
#include <algorithm>
#include <cmath>
#include <iostream>
using std::cin;
using std::cout;
using std::endl;
using std::max;
using std::min;
template <typename T>
inline const T &max(const T &a, const T &b, const T &c)
{
return max(a, max(b, c));
}
const double LOG2 = std::log(2);
int a[200010];
int maxval[200010][50];
int minval[200010][50];
int ans[200010][50];
int rans[200010][50];
int n, m;
inline void stInit()
{
for (int i = 1; i <= n; ++i)
minval[i][0] = maxval[i][0] = a[i];
for (int j = 1; 1 << j <= n; ++j)
for (int i = 1; i + (1 << j) - 1 <= n; ++i)
{
minval[i][j] = min(minval[i][j - 1], minval[i + (1 << (j - 1))][j - 1]);
maxval[i][j] = max(maxval[i][j - 1], maxval[i + (1 << (j - 1))][j - 1]);
ans[i][j] = max(ans[i][j - 1], ans[i + (1 << (j - 1))][j - 1],
maxval[i + (1 << (j - 1))][j - 1] - minval[i][j - 1]);
rans[i][j] = max(rans[i][j - 1], rans[i + (1 << (j - 1))][j - 1],
maxval[i][j - 1] - minval[i + (1 << (j - 1))][j - 1]);
}
}
inline int queryMax(int l, int r)
{
int k = static_cast<int>(std::log(r - l + 1) / LOG2);
return max(maxval[l][k], maxval[r - (1 << k) + 1][k]);
}
inline int queryMin(int l, int r)
{
int k = static_cast<int>(std::log(r - l + 1) / LOG2);
return min(minval[l][k], minval[r - (1 << k) + 1][k]);
}
inline int queryAns(int l, int r)
{
int k = static_cast<int>(std::log(r - l + 1) / LOG2);
if (l + (1 << k) > r)
return max(ans[l][k], ans[r - (1 << k) + 1][k]);
else
return max(ans[l][k], ans[r - (1 << k) + 1][k],
queryMax(l + (1 << k), r) - queryMin(l, r - (1 << k)));
}
inline int queryRans(int l, int r)
{
int k = static_cast<int>(std::log(r - l + 1) / LOG2);
if (l + (1 << k) > r)
return max(rans[l][k], rans[r - (1 << k) + 1][k]);
else
return max(rans[l][k], rans[r - (1 << k) + 1][k],
queryMax(l, r - (1 << k)) - queryMin(l + (1 << k), r));
}
int main()
{
cin >> n;
for (int i = 1; i <= n; ++i)
cin >> a[i];
stInit();
cin >> m;
while (m--)
{
int l, r;
cin >> l >> r;
if (l < r)
cout << queryAns(l, r) << endl;
else if (l > r)
cout << queryRans(r, l) << endl;
else
cout << 0 << endl;
}
return 0;
}
不难看出,查询的时间复杂度是O(1)的,预处理的时间复杂度是O(nlogn)的
codevs 3304 水果姐逛水果街Ⅰ的更多相关文章
- 水果姐逛水果街Ⅱ codevs 3305
3305 水果姐逛水果街Ⅱ 时间限制: 2 s 空间限制: 256000 KB 题目描述 Description 水果姐第二天心情也很不错,又来逛水果街. 突然,cgh又出现了.cgh施展了魔 ...
- code vs 3305 水果姐逛水果街Ⅱ
3305 水果姐逛水果街Ⅱ 时间限制: 2 s 空间限制: 256000 KB 题目等级 : 钻石 Diamond 题解 题目描述 Description 水果姐第二天心情也很不错, ...
- Codevs 3304 水果姐逛水果街Ⅰ 线段树
题目: http://codevs.cn/problem/3304/ 时间限制: 2 s 空间限制: 256000 KB 题目等级 : 钻石 Diamond 题解 题目描述 D ...
- CodeVs——T 3304 水果姐逛水果街Ⅰ
http://codevs.cn/problem/3304/ 时间限制: 2 s 空间限制: 256000 KB 题目等级 : 钻石 Diamond 题解 查看运行结果 题目描述 Des ...
- 水果姐逛水果街Ⅰ(codevs 3304)
题目描述 Description 水果姐今天心情不错,来到了水果街. 水果街有n家水果店,呈直线结构,编号为1~n,每家店能买水果也能卖水果,并且同一家店卖与买的价格一样. 学过oi的水果姐迅速发现了 ...
- Codevs 3305 水果姐逛水果街Ⅱ 倍增LCA
题目:http://codevs.cn/problem/3305/ 时间限制: 2 s 空间限制: 256000 KB 题目等级 : 钻石 Diamond 题解 题目描述 Des ...
- CodeVs——T 3305 水果姐逛水果街Ⅱ
http://codevs.cn/problem/3305/ 时间限制: 2 s 空间限制: 256000 KB 题目等级 : 钻石 Diamond 题解 查看运行结果 题目描述 De ...
- codevs 3305 水果姐逛水果街Ⅱ&&codevs3006
题目描述 Description 水果姐第二天心情也很不错,又来逛水果街. 突然,cgh又出现了.cgh施展了魔法,水果街变成了树结构(店与店之间只有一条唯一的路径). 同样还是n家水果店,编号为1~ ...
- codevs3305 水果姐逛水果街Ⅱ
本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000作者博客:http://www.cnblogs.com/ljh2000-jump/转 ...
- codevs3304 水果姐逛水果街
题目描述 Description 水果姐今天心情不错,来到了水果街. 水果街有n家水果店,呈直线结构,编号为1~n,每家店能买水果也能卖水果,并且同一家店卖与买的价格一样. 学过oi的水果姐迅速发现了 ...
随机推荐
- python第二次作业-titanic数据库练习
一.读入titanic.xlsx文件,按照教材示例步骤,完成数据清洗. titanic数据集包含11个特征,分别是: Survived:0代表死亡,1代表存活Pclass:乘客所持票类,有三种值(1, ...
- WPF (DataGridRowHeaderStyle)实现自义定行样式 并绑定数据
原文:WPF (DataGridRowHeaderStyle)实现自义定行样式 并绑定数据 功能阐述 就上面那图片 刚开始 考虑使用 RowHeaderTemplate 来实现 发现总绑定不上数据 ...
- 基于UDP协议的socket套接字编程
目录 一.UDP套接字简单示例 1.1 服务端 二.客户端 三.UPD套接字无粘包问题 3.1 服务端 3.2 客户端 四.qq聊天 4.1 服务端 4.2 客户端1 4.3 客户端2 4.4 运行结 ...
- python 各层级目录下的import方法
---恢复内容开始--- 以前经常使用python2.现在很多东西都切换到了python3,发现很多东西还是存在一些差异化的.跨目录import是常用的一种方法,并且有不同的表现形式,新手很容易搞混. ...
- C语言程序设计100例之(13):最大子段和
例13 最大子段和 题目描述 给出一段序列,选出其中连续且非空的一段使得这段和最大.例如在序列2,-4,3,-1,2,-4,3中,最大的子段和为4,该子段为3,-1,2. 输入格式 第一 ...
- Jenkins操作学习 -- 配置及使用
一.jenkins基本配置 1.在Jenkins首页,点击Manage Jenkins,然后再点击Manage Plugins插件管理,安装必要的插件.这里我只需要安装Git,因为第一次初始化安装没成 ...
- PHP 扩展与 ZEND 引擎的整合
PHP 扩展是对 PHP 功能的一个补充,编写完 PHP 扩展以后, ZEND 引擎需要获取到 PHP 扩展的信息,比如 phpinfo() 函数是如何列出 PHP 扩展的信息,PHP 扩展中的函数如 ...
- QOS限速
XX涉及的QOS限速主要有两种: 第一种是针对一个端口下双向IP互访: 第二种是针对多个端口下双向IP互访:(聚合car) 聚合car:是指能够对多个业务使用同一个car进行流量监控,即如果多个端口应 ...
- 关于 ASP.NET Core 中的 OData
1. BooksController using BooksODataService.Models; using Microsoft.AspNet.OData; using Microsoft.Asp ...
- WPF自定义控件之图片控件 AsyncImage
AsyncImage 是一个封装完善,使用简便,功能齐全的WPF图片控件,比直接使用Image相对来说更加方便,但它的内部仍然使用Image承载图像,只不过在其基础上进行了一次完善成熟的封装 Asyn ...