Wannafly挑战赛18 E 极差(线段树、单调栈)
Wannafly挑战赛18 E 极差
题意
给出三个长度为n的正整数序列,一个区间[L,R]的价值定义为:三个序列中,这个区间的极差(最大值与最小值之差)的乘积。
求所有区间的价值之和。答案对\(2^{32}\)取模。
题解
如果只有一个区间,我们可以枚举区间右端点,当右端点向右移动,左端点在[x, r]的一些区间的值会发生改变,可以用单调栈和线段树维护。
至于三个区间,可以用八棵线段树维护选中的某几个区间想乘的值。
代码
#include<bits/stdc++.h>
using namespace std;
#define fi first
#define se second
#define mp make_pair
#define pb push_back
#define rep(i, a, b) for(int i=(a); i<(b); i++)
#define sz(a) (int)a.size()
#define efi(a) a[sz(a)-1]
#define ese(a) a[sz(a)-2]
#define de(a) cout << #a << " = " << a << endl
#define dd(a) cout << #a << " = " << a << " "
#define all(a) a.begin(), a.end()
#define endl "\n"
typedef long long ll;
typedef unsigned int uint;
typedef pair<int, int> pii;
typedef vector<int> vi;
//---
const int N = 101010;
const ll P = 1ll<<32;
int n;
uint a[3][N];
struct Seg {
#define ls (rt<<1)
#define rs (ls|1)
static const int N = ::N<<2;
uint sum[8][N], la[3][N];
void build(int l, int r, int rt) {
sum[0][rt] = r-l+1;
if(l==r) return ;
int mid = l+r>>1;
build(l, mid, ls);
build(mid+1, r, rs);
}
inline void gao(int x, uint c, int rt) {
int p = 1<<x;
rep(i, 1, 8) if((i&p)==p) {
sum[i][rt] += sum[i^p][rt] * c;
}
la[x][rt] += c;
}
inline void down(int rt) {
rep(x, 0, 3) if(la[x][rt]) {
gao(x, la[x][rt], ls);
gao(x, la[x][rt], rs);
la[x][rt] = 0;
}
}
inline void up(int rt) {
rep(i, 1, 8) sum[i][rt] = sum[i][ls] + sum[i][rs];
}
void upd(int L, int R, int p, uint c, int l, int r, int rt) {
if(L<=l&&r<=R) {
gao(p, c, rt);
return ;
}
int mid = l+r>>1;
down(rt);
if(L<=mid) upd(L, R, p, c, l, mid, ls);
if(R>=mid+1) upd(L, R, p, c, mid+1, r, rs);
up(rt);
}
uint qry(int L, int R, int l, int r, int rt) {
if(L<=l&&r<=R) return sum[7][rt];
int mid = l+r>>1;
down(rt);
uint ans = 0;
if(L<=mid) ans += qry(L, R, l, mid, ls);
if(R>=mid+1) ans += qry(L, R, mid+1, r, rs);
up(rt);
return ans;
}
}seg;
int pma[3], pmi[3];
int ma[3][N], mi[3][N];
int main() {
std::ios::sync_with_stdio(false);
std::cin.tie(0);
///
cin >> n;
///read
rep(i, 0, 3) rep(j, 1, n+1) cin >> a[i][j];
///solve
seg.build(1, n, 1);
uint ans = 0;
rep(j, 1, n+1) {
rep(i, 0, 3) {
while(pmi[i] && a[i][mi[i][pmi[i]]] > a[i][j]) {
seg.upd(mi[i][pmi[i]-1]+1, mi[i][pmi[i]], i, a[i][mi[i][pmi[i]]], 1, n, 1);
--pmi[i];
}
mi[i][++pmi[i]] = j;
seg.upd(mi[i][pmi[i]-1]+1, j, i, -a[i][j], 1, n, 1);
while(pma[i] && a[i][ma[i][pma[i]]] < a[i][j]) {
seg.upd(ma[i][pma[i]-1]+1, ma[i][pma[i]], i, -a[i][ma[i][pma[i]]], 1, n, 1);
--pma[i];
}
ma[i][++pma[i]] = j;
seg.upd(ma[i][pma[i]-1]+1, j, i, a[i][j], 1, n, 1);
}
ans += seg.sum[7][1];
}
cout << ans << endl;
return 0;
}
Wannafly挑战赛18 E 极差(线段树、单调栈)的更多相关文章
- Codeforces 1175F - The Number of Subpermutations(线段树+单调栈+双针/分治+启发式优化)
Codeforces 题面传送门 & 洛谷题面传送门 由于这场的 G 是道毒瘤题,蒟蒻切不动就只好来把这场的 F 水掉了 看到这样的设问没人想到这道题吗?那我就来发篇线段树+单调栈的做法. 首 ...
- Codeforces 781E Andryusha and Nervous Barriers 线段树 单调栈
原文链接https://www.cnblogs.com/zhouzhendong/p/CF781E.html 题目传送门 - CF781E 题意 有一个矩形,宽为 w ,高为 h .一开始会有 w 个 ...
- 洛谷P4425 转盘 [HNOI/AHOI2018] 线段树+单调栈
正解:线段树+单调栈 解题报告: 传送门! 1551又是一道灵巧连题意都麻油看懂的题,,,,所以先解释一下题意好了,,,, 给定一个n元环 可以从0时刻开始从任一位置出发 每次可以选择向前走一步或者在 ...
- 线段树+单调栈+前缀和--2019icpc南昌网络赛I
线段树+单调栈+前缀和--2019icpc南昌网络赛I Alice has a magic array. She suggests that the value of a interval is eq ...
- 牛客多校第四场sequence C (线段树+单调栈)
牛客多校第四场sequence C (线段树+单调栈) 传送门:https://ac.nowcoder.com/acm/contest/884/C 题意: 求一个$\max {1 \leq l \le ...
- BZOJ.4540.[HNOI2016]序列(莫队/前缀和/线段树 单调栈 RMQ)
BZOJ 洛谷 ST表的一二维顺序一定要改过来. 改了就rank1了哈哈哈哈.自带小常数没办法. \(Description\) 给定长为\(n\)的序列\(A_i\).\(q\)次询问,每次给定\( ...
- [Codeforces1132G]Greedy Subsequences——线段树+单调栈
题目链接: Codeforces1132G 题目大意:给定一个序列$a$,定义它的最长贪心严格上升子序列为$b$满足若$a_{i}$在$b$中则$a_{i}$之后第一个比它大的也在$b$中.给出一个数 ...
- AtCoder Regular Contest 063 F : Snuke’s Coloring 2 (线段树 + 单调栈)
题意 小 \(\mathrm{C}\) 很喜欢二维染色问题,这天他拿来了一个 \(w × h\) 的二维平面 , 初始时均为白色 . 然后他在上面设置了 \(n\) 个关键点 \((X_i , Y_i ...
- cdqz2017-test10-rehearsal(CDQ分治&可持久化线段树&单调栈)
题意: 给出n个三元组 e[i]=(si,ti,wi) 第i个三元组的价值为 Σ w[j] ,j 满足以下4个条件: 1.j<i 2.tj<ti 3.sj<si 4.不存在j< ...
随机推荐
- Python制作回合制手游外挂简单教程(中)
接着上篇的博文,今天我们讲如何实现自动组队刷道 引入: 自动组队刷道的流程是先点击刷道按钮.再点击前往按钮.再点击便捷组队······ 这些操作上篇博文已经告诉我们怎么做了,利用picpick丈量坐标 ...
- 和为S的连续正数序列★★
题目描述 小明很喜欢数学,有一天他在做数学作业时,要求计算出9~16的和,他马上就写出了正确答案是100.但是他并不满足于此,他在想究竟有多少种连续的正数序列的和为100(至少包括两个数).没多久,他 ...
- JVM垃圾回收机制总结
对于垃圾回收机制我先抛出三个问题: ①哪些内存需要回收? ②什么时候回收? ③如何回收? 下面我们主要针对这三个问题来研究JVM GC 一.哪些内存需要回收? 1.JAVA使用可达性分析法来判断对象是 ...
- js文件加载太慢,JavaScript文件加载加速
原文出自:https://blog.csdn.net/seesun2012 js脚本加载太慢,JavaScript脚本加载加速(亲测有效) 测试背景: JS文件大小:6.1kB 传统形式加载js文件: ...
- unity GUI Layout 组件(全)
[expand 扩张][fitter 装配工] [envelope 信封,包装] Layout 布局 三种. Horizontal Layout Group 水平布局 Padding:内边距,单位 ...
- RabbitMQ---9、消息确认机制(事务+Confirm)
转载至:https://blog.csdn.net/u013256816/article/details/55515234 参考资料:https://www.cnblogs.com/520playbo ...
- android 使用图片轮播图---banner 使用
转自:https://github.com/youth5201314/banner 使用步骤 Step 1.依赖banner Gradle dependencies{ compile 'com.you ...
- 【SSH网上商城项目实战22】获取银行图标以及支付页面的显示
转自: https://blog.csdn.net/eson_15/article/details/51452243 从上一节的小demo中我们搞清楚了如何跟易宝对接以及易宝的支付流程.这一节 ...
- Java Future源码分析
JDK future框架,提供了一种异步编程模式,基于线程池的.将任务runnable/callable提交到线程池executor,返回一个Future对象.通过future.get()获取执行结果 ...
- Bootstrap网格
首先了解一下,什么是网格? 在平面设计中,网格是一种由一系列用于组织内容的相交的直线(垂直的.水平的)组成的结构(通常是二维的).它广泛应用于打印设计中的设计布局和内容结构.在网页设计中,它是一种用于 ...