[NOI Online 2022 提高组] 丹钓战(单调栈 + 树状数组 / 主席树)

problem

luogu-P8251

solution

按照题意模拟单调栈。

求出对于 iii 而言,当时单调栈的栈顶元素记为 pip_ipi

如果到 iii 时,栈顶已经为 pip_ipi 了,意味着这中间的所有元素要么是被 iii 弹出,要么就是被 iii 前面的某些元素弹出,这些元素又被 iii 弹出。

总而言之,会发现当询问的 pi<lp_i<lpi<liii 所代表的二元组就是成功的。

于是我们只需要求 [l,r][l,r][l,r] 内有多少个 i∈[l,r]s.t.pi<li\in[l,r]\ s.t.\ p_i<li[l,r] s.t. pi<l

写个主席树,或者差分一下转化成树状数组二维数点都行。

code

#include <bits/stdc++.h>
using namespace std;
#define maxn 500005
struct node { int x, p, k, id; }q[maxn << 1];
int n, Q;
int a[maxn], b[maxn], p[maxn], t[maxn], ans[maxn];
stack < int > s;void read( int &x ) {x = 0; char s = getchar();while( s < '0' or s > '9' ) s = getchar();while( '0' <= s and s <= '9' ) {x = ( x << 1 ) + ( x << 3 ) + ( s ^ 48 );s = getchar();}	
}void print( int x ) {if( x > 9 ) print( x / 10 );putchar( x % 10 + '0' );
}namespace BIT {void add( int x ) { x ++; for(;x <= n;x += x & -x) t[x] ++; }int ask( int x ) { x ++; int cnt = 0; for(x;x;x -= x & -x) cnt += t[x]; return cnt; }
}int main() {read( n ), read( Q );for( int i = 1;i <= n;i ++ ) read( a[i] );for( int i = 1;i <= n;i ++ ) read( b[i] );for( int i = 1;i <= n;i ++ ) {while( ! s.empty() and (a[s.top()] == a[i] or b[i] >= b[s.top()]) ) s.pop();if( ! s.empty() ) p[i] = s.top();s.push( i );}for( int i = 1, l, r;i <= Q;i ++ ) {read( l ), read( r );q[i] = (node){ l - 1, l - 1, -1, i };q[i + Q] = (node){ r, l - 1, 1, i };}sort( q + 1, q + (Q << 1 | 1), [](node a, node b){ return a.x < b.x; } );int j = 1; while( ! q[j].x ) j ++;for( int i = 1;i <= n;i ++ ) {BIT :: add( p[i] );for( ;q[j].x == i and j <= (Q << 1);j ++ ) ans[q[j].id] += q[j].k * BIT :: ask( q[j].p );}for( int i = 1;i <= Q;i ++ ) print( ans[i] ), putchar( '\n' );return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/316334.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Acwing 252. 树

Acwing 252. 树 题意&#xff1a; 给定一个有 N 个点&#xff08;编号 0,1,…,N−1&#xff09;的树&#xff0c;每条边都有一个权值&#xff08;不超过 1000&#xff09;。 树上两个节点 x 与 y 之间的路径长度就是路径上各条边的权值之和。 求长度不超过 K 的路径有多少条…

.net 4.5部署到docker容器

.NET FX 应用程序也是可以容器化的&#xff0c;容器化的选项有两个&#xff1a;部署到windows容器部署到linux容器部署到windows容器由于.net本身就是运行在windows平台的&#xff0c;所以它与windows容器也是更加适合&#xff0c;你可以以iis镜像为基础&#xff0c;去编写你的…

[NOI Online 2022 提高组] 讨论(巧妙的切入方式)

problem luogu-P8252 solution 本题最难处理的就是两个人会做的题目集合是包含关系的限制。 将所有人按会做的题数从大到小排序。 然后枚举 iii&#xff0c;只要这个人和之前某个人存在有至少一道公共的题目&#xff0c;并且保证这个人有新的题目&#xff0c;那么这两个人…

P4149 [IOI2011]Race

P4149 [IOI2011]Race 题意&#xff1a; 给一棵树&#xff0c;每条边有权。求一条简单路径&#xff0c;权值和等于 k&#xff0c;且边的数量最小。 题解&#xff1a; 用t[i]:长度为i的路径包含的最少边数 按照子树顺序&#xff0c;依次用dep[u]t[K-d[u]]更新ans&#xff0c;…

将传统 WPF 程序迁移到 DotNetCore 3.0

介绍由于历史原因&#xff0c;基于 Windows 平台存在着大量的基于 .NetFramework 开发的 WPF 和 WinForm 相关程序&#xff0c;如果将这些程序全部基于 DotNetCore 3.0 重写一遍显然是不现实的&#xff0c;但是 DotNetCore 是未来发展的趋势。所以本文通过以 WPF 为例&#xff…

[CodeForces 1603C] Extreme Extension(贪心 + 数论分块优化dp)

problem CodeForces solution observation1:\text{observation1}:observation1: 对于一个非空子段 [l,r][l,r][l,r]&#xff0c;最后一个元素 ara_rar​ 一定不会被操作。 observation2:\text{observation2}:observation2: 基于上一条进一步地有&#xff0c;对于一个非空子段…

.NET Core 时代已经到了,你准备好了吗

今天很多人都收到了阿里云函数计算支持.NET Core的短信了。通过访问 https://help.aliyun.com/document_detail/112379.html 你可以看到最新的说明。现在和过去的两年不同&#xff0c;因为最恶劣的时期已经过去&#xff0c;经历过了最黑暗的时刻&#xff0c;我们正在走向光明的…

cf600 E. Lomsat gelral

cf600 E. Lomsat gelral 题意&#xff1a; 给出一个树&#xff0c;求出每个节点的子树中出现次数最多的颜色的编号和 题解&#xff1a; 树上启发式合并 树上启发式合并讲解 其实就是&#xff1a;递归轻儿子&#xff0c;消除影响&#xff0c;递归重儿子&#xff0c;不消除影…

ASP.NET Core appsettings.json文件(9)《从零开始学ASP.NET CORE MVC》:

本文出自《从零开始学ASP.NET CORE MVC》推荐文章&#xff1a;ASP.NET Core launchsettings.json文件ASP.NET Core appsettings.json文件在本视频中&#xff0c;我们将讨论ASP.NET Core 项目中appsettings.json文件的重要性。在以前的ASP.NET版本中&#xff0c;我们将应用程序配…

[CQOI2018] 交错序列(矩阵加速优化dp)

problem luogu-P4456 solution 预处理阶乘和阶乘的逆元&#xff0c;枚举 111 出现次数 iii&#xff0c;∑(n−i1i)(n−i)aib\sum\binom{n-i1}{i}(n-i)^ai^b∑(in−i1​)(n−i)aib。 (n−i1i)\binom{n-i1}{i}(in−i1​) 如何推出来? 从 nnn 个中选 iii 个 (ni)\binom ni(in​…

P4245 【模板】任意模数多项式乘法(NTT)

题意&#xff1a; P4245 【模板】任意模数多项式乘法 题解&#xff1a; NTT模板&#xff0c;记录一下 代码&#xff1a; #include <bits/stdc.h>using namespace std;#define REP(i, a, b) for (int i (a), _end_ (b); i < _end_; i) #define debug(...) fprintf…

在Windows上使用Docker运行.NetCore

今天我们来说下如何在windows下使用docker运行.net core&#xff0c;既然是docker&#xff0c;那么我们首先得在windows上安装docker。在Windows安装 docker 有两种选择 &#xff1a;1、docker for windows2、docker toolbox 区别&#xff1a;docker for windows-64位Windows 1…

[AtCoder Educational DP Contest] J - Sushi(期望dp)

problem luogu 现有N(1≤N≤300)N(1 ≤ N ≤ 300)N(1≤N≤300) 个盘子&#xff0c;编号为1,2,3,…,N1,2,3,…,N1,2,3,…,N。 第 iii个盘中放有 ai(1≤ai≤3)a_i(1≤a_i ≤3)ai​(1≤ai​≤3)个寿司。 接下来每次执行以下操作&#xff0c;直至吃完所有的寿司。 从第 1,2,3,…

cf570 D. Tree Requests

cf570 D. Tree Requests 题意&#xff1a; 给定一个以 1 为根的 n 个结点的树&#xff0c;每个点上有一个字母&#xff08;a-z&#xff09;。每次询问 a, b 查询以 a 为根的子树内深度为 b 的结点上的字母重新排列之后是否能构成回文串。 题解&#xff1a; 回文串形成条件&…

浅谈C#在网络波动时防重复提交

前几天&#xff0c;公司数据库出现了两条相同的数据&#xff0c;而且时间相同&#xff08;毫秒也相同&#xff09;。排查原因&#xff0c;发现是网络波动造成了重复提交。由于网络波动而重复提交的例子也比较多&#xff1a;网络上&#xff0c;防重复提交的方法也很多&#xff0…

[AtCoder Educational DP Contest] V - Subtree(树形dp + 前缀积/后缀积)

problem luogu 给一棵树&#xff0c;对每一个节点染成黑色或白色。 对于每一个节点&#xff0c;求强制把这个节点染成黑色的情况下&#xff0c;所有的黑色节点组成一个联通块的染色方案数&#xff0c;答案对 MMM 取模。 1≤n≤1e5,2≤M≤1e91\le n\le 1e5,2\le M\le 1e91≤n…

P2634 [国家集训队]聪聪可可(点分治做法)

P2634 [国家集训队]聪聪可可 题意&#xff1a; 一颗n个点的树&#xff0c;问其中两点之间的边上数的和加起来是3的倍数的点对有多少个&#xff1f; 输出这样的点对所占比例 题解&#xff1a; 因为是求三的倍数&#xff0c;我们num来记录%30&#xff0c;1&#xff0c;2的数量…

C#并行编程(4):基于任务的并行

C#中的任务Task在C#编程中&#xff0c;实现并行可以直接使用线程&#xff0c;但使用起来很繁琐&#xff1b;也可以使用线程池&#xff0c;线程池很大程度上简化了线程的使用&#xff0c;但是也有着一些局限&#xff0c;比如我们不知道作业什么时候完成&#xff0c;也取不到作业…

[AtCoder Educational DP Contest] W - Intervals(线段树优化dp)

problem 给定 mmm 条规则形如 (li,ri,ai)(l_i,r_i,a_i)(li​,ri​,ai​)&#xff0c;对于一个 01 串&#xff0c;其分数的定义是&#xff1a;对于第 iii 条规则&#xff0c;若该串在 [li,ri][l_i,r_i][li​,ri​] 中至少有一个 1&#xff0c;则该串的分数增加 aia_iai​。 你…

P2634 [国家集训队]聪聪可可(树形dp)

题意&#xff1a; 一颗n个点的树&#xff0c;问其中两点之间的边上数的和加起来是3的倍数的点对有多少个&#xff1f; 输出这样的点对所占比例 题解&#xff1a; 树形dp求解 因为是求长度为3的倍数&#xff0c;模3的结果只有0/1/2&#xff0c;我们可以单独考虑作为一维。 设…