题目链接 Drazil and Park

中文题面 传送门

如果他选择了x和y,那么他消耗的能量为dx + dx + 1 + ... + dy - 1 + 2 * (hx + hy).

把这个式子写成这个形式

(d1 + d2 + ... + dy - 1 + 2 * hy) + (2 * hx - (d1 + d2 + ... + dx - 1))

令(2 * hk - (d1 + d2 + ... + dk - 1)) = Lk 

   (d1 + d2 + ... + dk - 1 + 2 * hk) = Rk

我们在查询的时候,就要在[a, b]内找到u, v 使得L[u] + R[v] 最大

而当 u < v 的时候,总有 L[u] + R[v] > L[v] + R[u]

那我们放心地在[a, b]这个区间内找u和v,使L[u]和R[v]分别为这段区间上的最大值

这个过程用ST表维护即可。

但是我们要注意u = v的情况,也就是说求出来的u和v可能相等。

而题目的要求是u和v必须不相等

那么这个时候我们分类讨论一下,把[a, b]在u这一点分割成两个区间,在[a, u - 1]和[u + 1, b]里去找v

同理把[a, b]在v这一点分割成两个区间,在[a, v - 1]和[v + 1, b]里去找u

问题就这么解决了

#include <bits/stdc++.h>

using namespace std;

#define rep(i, a, b)	for (int i(a); i <= (b); ++i)
#define dec(i, a, b) for (int i(a); i >= (b); --i) typedef long long LL;
typedef pair <LL, int> PII; const int N = 2e5 + 10;
const int A = 19; int n, m;
LL d[N], h[N], s[N];
PII x[N], y[N], f[N][A], g[N][A];
int L, R;
int et; void ST(){
rep(i, 1, n) f[i][0] = x[i];
rep(j, 1, 18)
rep(i, 1, n)
if ((i + (1 << j) - 1) <= n) f[i][j] = max(f[i][j - 1], f[i + (1 << (j - 1))][j - 1]); rep(i, 1, n) g[i][0] = y[i];
rep(j, 1, 18)
rep(i, 1, n)
if ((i + (1 << j) - 1) <= n) g[i][j] = max(g[i][j - 1], g[i + (1 << (j - 1))][j - 1]);
} inline PII Xmax(int l, int r){
if (l > r) return make_pair(-1e18, 0);
int k = (int)log2((double)(r - l + 1));
return max(f[l][k], f[r - (1 << k) + 1][k]);
} inline PII Ymax(int l, int r){
if (l > r) return make_pair(-1e18, 0);
int k = (int)log2((double)(r - l + 1));
return max(g[l][k], g[r - (1 << k) + 1][k]);
} LL solve(int l, int r){
PII n1 = Xmax(l, r), n2 = Ymax(l, r);
if (n1.second != n2.second) return n1.first + n2.first;
PII n3 = max(Ymax(l, n1.second - 1), Ymax(n1.second + 1, r));
PII n4 = max(Xmax(l, n2.second - 1), Xmax(n2.second + 1, r));
return max(n1.first + n3.first, n2.first + n4.first);
} int main(){ scanf("%d%d", &n, &m);
rep(i, 1, n) scanf("%lld", d + i);
rep(i, 1, n) scanf("%lld", h + i); rep(i, n + 1, n << 1) d[i] = d[i - n];
rep(i, n + 1, n << 1) h[i] = h[i - n]; rep(i, 2, n << 1) s[i] = s[i - 1] + d[i - 1];
rep(i, 1, n << 1) x[i] = make_pair(2 * h[i] + s[i], i);
rep(i, 1, n << 1) y[i] = make_pair(2 * h[i] - s[i], i); et = n;
n <<= 1;
ST();
n = et; while (m--){
int l, r;
scanf("%d%d", &l, &r);
if (r >= l) L = r + 1, R = l - 1 + n; else L = r + 1, R = l - 1;
printf("%d %d\n", L, R);
printf("%lld\n", solve(L, R));
} return 0;
}

Codeforces 515E Drazil and Park (ST表)的更多相关文章

  1. Codeforces 475D 题解(二分查找+ST表)

    题面: 传送门:http://codeforces.com/problemset/problem/475/D Given a sequence of integers a1, -, an and q ...

  2. Codeforces 873E Awards For Contestants ST表

    原文链接https://www.cnblogs.com/zhouzhendong/p/9255885.html 题目传送门 - CF873E 题意 现在要给 $n(n\leq 3000)$ 个学生颁奖 ...

  3. Codeforces 803G Periodic RMQ Problem ST表+动态开节点线段树

    思路: (我也不知道这是不是正解) ST表预处理出来原数列的两点之间的min 再搞一个动态开节点线段树 节点记录ans 和标记 lazy=-1 当前节点的ans可用  lazy=0 没被覆盖过 els ...

  4. CodeForces 516C Drazil and Park 线段树

    原文链接http://www.cnblogs.com/zhouzhendong/p/8990745.html 题目传送门 - CodeForces 516C 题意 在一个环上,有$n$棵树. 给出每一 ...

  5. codeforces 516c// Drazil and Park// Codeforces Round #292(Div. 1)

    题意:一个圆环上有树,猴子上下其中一棵树,再沿着换跑,再上下另一棵树.给出一个区间,问最大的运动距离是. 给出区间大小dst,和数高数组arr. 设区间[x,y],a[x]=2*arr[x]+dst[ ...

  6. Codeforces Round #292 (Div. 1) C. Drazil and Park 线段树

    C. Drazil and Park 题目连接: http://codeforces.com/contest/516/problem/C Description Drazil is a monkey. ...

  7. ST表入门学习poj3264 hdu5443 hdu5289 codeforces round #361 div2D

    ST算法介绍:[转自http://blog.csdn.net/insistgogo/article/details/9929103] 作用:ST算法是用来求解给定区间RMQ的最值,本文以最小值为例 方 ...

  8. Codeforces Round #422 (Div. 2)E. Liar sa+st表+dp

    题意:给你两个串s,p,问你把s分开顺序不变,能不能用最多k段合成p. 题解:dp[i][j]表示s到了前i项,用了j段的最多能合成p的前缀是哪里,那么转移就是两种,\(dp[i+1][j]=dp[i ...

  9. 【CodeForces】713 D. Animals and Puzzle 动态规划+二维ST表

    [题目]D. Animals and Puzzle [题意]给定n*m的01矩阵,Q次询问某个子矩阵内的最大正方形全1子矩阵边长.n,m<=1000,Q<=10^6. [算法]动态规划DP ...

随机推荐

  1. CF547D Mike and Fish 建图

    题意: 有点长→CF547DMike and Fish. 分析: 其实也没什么好分析的,我这也是看的题解. (不过,那篇题解好像文字的代码不太对劲) 这里直接说做法,正确性自证: 对输入的,将横.纵坐 ...

  2. 初涉二维数点问题&&bzoj1935: [Shoi2007]Tree 园丁的烦恼

    离线好评 Description 很久很久以前,在遥远的大陆上有一个美丽的国家.统治着这个美丽国家的国王是一个园艺爱好者,在他的皇家花园里种植着各种奇花异草.有一天国王漫步在花园里,若有所思,他问一个 ...

  3. 编写testplan

    编写验证计划是验证工作核心技能.衡量标准是完备性.可是写一个完备的验证计划,才开始不是一件容易的事情,需要不断的练习实践. 1.验证计划主要从设计的futurelist中提取.     复杂的futu ...

  4. perl学习之:正则表达式

  5. Python模块概念

    补充:生成器表达式 将列表生成器的中括号改为小括号就是生成器表达式 res = [i for i in range(10) if i > 5]  #  列表生成式 res = (i for i ...

  6. Python全栈工程师之html学习笔记

    https://www.bilibili.com/video/av15241731 笔记来源:黑马程序员 HTML(Hyper Text Markup Language):超文本标签语言 HTML标签 ...

  7. LeetCode101--对称二叉树

    ''' 给定一个二叉树,检查它是否是镜像对称的. ''' class TreeNode: def __init__(self, x): self.val = x self.left = None se ...

  8. PAT Basic 1069

    1069 微博转发抽奖 小明 PAT 考了满分,高兴之余决定发起微博转发抽奖活动,从转发的网友中按顺序每隔 N 个人就发出一个红包.请你编写程序帮助他确定中奖名单. 输入格式: 输入第一行给出三个正整 ...

  9. 自学入门 Python 优质中文资源索引

    所有资源基于 Python3 版本,全部中文内容,适用于 爬虫 / Web / 数据 方向,每个单元根据学习习惯从 书籍 / 文档 / 视频 中选择一类即可,建议任选一本书籍,然后配合文档类进行学习. ...

  10. idea导入jdk源码查看(xjl456852原创)

    idea添加了jdk环境后,却无法查看jdk源码,只能通过idea自带的反编译查看,看起来有些不爽. 下面来说一下如何设置,导入jdk源码,查看时通过源码查看jdk. 1.点击菜单 File -> ...