首页 > 其他分享 >CF1647F Madoka and Laziness 题解

CF1647F Madoka and Laziness 题解

时间:2024-08-09 19:16:06浏览次数:15  
标签:CF1647F Madoka leftarrow 题解 最大值 单峰 序列 cases dp

CF1647F

给定排列 \(p\),将其划分为两个单峰子序列,求两个单峰子序列的峰的组合的情况数。

\(2 \leq n \leq 5\times 10^5\)

  • 首先要注意到一个非常常见的地方:两个单峰子序列中的一个的峰值一定在整个排列 \(p\) 的最大值处

  • 这个非常显然,但并不注意到他的重要性,容易被忽视

  • 为了方便,我们设序列最大值为峰顶的子序列为 \(a\),另外一个为 \(b\),序列最大值位置为 \(x\)

  • 因此我们可以在这个峰值的基础上枚举另一个单峰子序列的峰值位置,因此原序列就可以被划分成 \(3\) 种情况:

      • 子序列 a 只需保持严格上升即可,而 b 要求最大值尽可能的小
    • 设 dp_i 表示前 i 个数划分成两个严格上升序列,不以 p_i 结尾的子序列最大值最小

    • 可以得到转移:

    • \[\begin{cases} dp_i \leftarrow dp_{i-1} & (p_i > p_{i-1}) \\ dp_i \leftarrow a_i & (dp_{i-1} < a_i) \\ \end{cases} \]

      • 需要划分序列为递增与递减序列
    • 设 \(f_i\) 表示把 \([x,i]\) 划分为一个上升序列和一个下降序列,上升序列的起始 \(\geq dp_x\),末尾值属于上升序列时下降序列末尾最小可能值

    • 设 \(g_i\) 表示把 \([x,i]\) 划分为一个上升序列和一个下降序列,上升序列的起始 \(\geq dp_x\),末尾值属于下降序列时上升序列末尾最大可能值

    • 可以得到转移:

    • \[\begin{cases} f_i \leftarrow f_{i-1} & (p_{i-1} < p_i) \\ f_i \leftarrow p_{i-1} & (g_{i-1} < p_i) \\ g_i \leftarrow g_{i-1} & (p_{i-1} > p_i) \\ g_i \leftarrow p_{i-1} & (f_{i-1} > p_i) \\ \end{cases} \]

      • 与 1 情况类似
  • 先预处理出 \(dp\) 式子,然后枚举 \(b\) 序列的最大值进行更新答案即可

  • 最终复杂度 \(O(n)\)

标签:CF1647F,Madoka,leftarrow,题解,最大值,单峰,序列,cases,dp
From: https://www.cnblogs.com/fox-konata/p/18351374

相关文章

  • luogu题解:P10456 The Pilots Brothers' refrigerator【缺少 SPJ】
    思路此题题意酷似P10449.费解的开关。https://www.luogu.com.cn/problem/P10449不同之处便是状态连锁改变不同,但做法截然不同,此题是一个\(4\times4\)的矩阵。暴力枚举的复杂度是\(O(10^7)\),即\(2^{16}\times16\times16=16777216\),\(10^7\)的复杂度可以通......
  • P2901题解
    题目大意输出一张有向带权图前k短路的长度思路分析这是道k短路板子题我们可以用Astar算法来实现它OIwiki相关算法的网页简单来讲,Astar定义了一个估值函数f(x)=g(x)+h(x)g(x)表示由起点到达x点的路程(不一定是最短路),而h(x)则是终点到x点的最短路程这个估值函数可以预估从该......
  • Codeforces 165E Compatible Numbers 题解
    思路高维前缀和高维前缀和把数的二进制看成一个集合,二进制的每一位为\(1\)为全集\(V\)。根据题目描述,若两数\(a,b\)相容,则\(a\operatorname{and}b=0\),容易发现,\(b\in\complement_{V}a\),所以我们只需要用高维前缀和处理出\(\complement_{V}a\)的一个元素即可。......
  • ABC349D题解
    [ABC349D]DivideInterval题解传送门:luogu|atcoder题目简述给定非负整数\(l\)和\(r\)(\(l<r\)),令\(S(l,r)\)表示序列\((l,l+1,\ldots,r-2,r-1)\),其中包含从\(l\)到\(r-1\)的所有整数。此外,一个序列被称为“好序列”,当且仅当它可以表示为\(S(2^ij,2^{i}(j+1))\),......
  • AT_past202010_m 筆塗り 题解
    题目传送门前置知识线段树|树链剖分解法观察到要维护树上信息,且更改的呈链状,考虑进行树链剖分。将边权转化成点权,钦定边权给了深度更深的那个点,注意更新时不能更新\(\operatorname{LCA}\)。区间赋值和单点查询用线段树维护即可。代码#include<bits/stdc++.h>usingnam......
  • 如何避免自己问题解决缓慢导致项目周期延长
    在公司实习期间,我发现自己对业务的熟悉程度不足,导致在预期时间和实际完成时间上存在差异。虽然这种情况在后期有所改善,但前期的压力相对较大。为此,我总结了以下几点经验和改进措施:1.问题描述与现有分析我们今天的工作进展如何?当前诊断的调查进展如何?如果进展缓慢,是什么原因?需......
  • ABC349D题解
    [ABC349D]DivideInterval题解传送门:luogu|atcoder题目简述给定非负整数$l$和$r$($l<r$),令$S(l,r)$表示序列$(l,l+1,\ldots,r-2,r-1)$,其中包含从$l$到$r-1$的所有整数。此外,一个序列被称为“好序列”,当且仅当它可以表示为$S(2^ij,2^{i}(j+1))$,其中$i$和$j$......
  • # Cocos通过Electron打包web应用后,在触屏一体机设备触摸滑动无效问题解决
    Cocos通过Electron打包web应用后,在触屏一体机设备触摸滑动无效问题解决已经很晚了,刚刚解决这个问题,还是想记录一下,因为刚刚接触cocos没多久,这个问题困扰了我很久。背景接手了一个答题小游戏,由于涉及敏感信息就不在这里截图了,交接到我手里的是用cocos开发的,之前从来没有接触......
  • P8819题解
    题目大意现在有个有向图图,共有n个点,m条边总共有四种操作:操作1:将一条边打上标记操作2:将一个点出发的所有边打上标记操作3:将一条边移除标记操作4:将一个点出发的所有边移除标记打上标记的边视为被移除每次操作进行一次询问,如果每个点出度都是1,整张图是个强连通图,那么输出"YES......