首页 > 其他分享 >[题解] CF1748E Yet Another Array Counting Problem

[题解] CF1748E Yet Another Array Counting Problem

时间:2023-11-14 11:44:35浏览次数:56  
标签:le rs int 题解 CF1748E MAXN ls Problem dp

Yet Another Array Counting Problem

给你一个长度为 \(n\) 的序列和一个数 \(m\),求有多少个长度为 \(n\) 的序列 \(b\) 满足:

  • \(\forall i \in [1, n], b_i \in [1, m]\)。
  • 对于每个区间 \([l, r]\),\(b\) 中最大值最靠左的位置和 \(a\) 相同。

\(n, m \le 2 \times 10^5, n \times m \le 10^6\)。

看到数最大值的位置相同的数列个数,自然可以想到建笛卡尔树后树形 dp。

记 \(f_{u, i}\) 表示当前在节点 \(u\),填的数是 \(i\) 的方案数,\(g_{u, i} = \sum_{j \le i} f_{u, j}\)。

此时的限制是左儿子中的数都小于当前节点的数,右儿子中的数都小于等于当前节点的数。所以转移是:

\[f_{u, i} \leftarrow g_{ls_u, i - 1} \times g_{rs_u, i} \]

然后直接转移就好了。

时间复杂度 \(O(nm)\)。

constexpr int MAXN = 2e5 + 9;
int n, m, a[MAXN], ls[MAXN], rs[MAXN];
vector<int> f[MAXN], stk;

void slv() {
	n = Read<int>(), m = Read<int>();
	for (int i = 1; i <= n; i ++) a[i] = Read<int>();
	for (int i = 1; i <= n; i ++) {
		while (stk.size() && a[stk.back()] < a[i])
			ls[i] = stk.back(), stk.pop_back();
		if (stk.size()) rs[stk.back()] = i;
		stk.emplace_back(i);
	}
	int rt = stk.front();
	function<void(int)> dp = [&](int u) {
		if (!u) return; f[u].resize(m + 1);
		dp(ls[u]), dp(rs[u]);
		for (int i = 1; i <= m; i ++) {
			f[u][i] = mul(f[ls[u]][i - 1], f[rs[u]][i]),
			cadd(f[u][i], f[u][i - 1]);
		}
		return;
	};
	f[0].resize(m + 1);
	for (int i = 0; i <= m; i ++) f[0][i] = 1;
	dp(rt);
	Write(f[rt][m], '\n');
	return;
}

标签:le,rs,int,题解,CF1748E,MAXN,ls,Problem,dp
From: https://www.cnblogs.com/definieren/p/17831263.html

相关文章

  • [题解] P4435 [COCI2017-2018#2] ​​Garaža
    P4435[COCI2017-2018#2]Garaža给你一个长度为\(n\)的序列\(a\),单点改,查询区间\(\gcd\)不为1的子区间个数。\(n,Q\le10^5,a_i\le10^9\)。先看单次全局查询怎么做。考虑一个分治,每次我们要计算跨过分治中心\(mid\)的答案。因为这个是单调的,所以可以双指针做......
  • 【题解】P4768 [NOI2018] 归程 / Kruskal 重构树
    补补以前懒得总结的零碎东西。kruskal重构树使用条件:求无向图中两点之间所有路径的最大边权的最小值构造:依kruskal得到最小生成树从小到大考虑生成树中的边\((u,v)\)对于\((u,v)\),新建一个结点,作为重构树中\(u,v\)的父结点该结点的点权为\((u,v)\)的......
  • SPOJ1805 HISTOGRA - Largest Rectangle in a Histogram 题解
    LinkSPOJ1805HISTOGRA-LargestRectangleinaHistogramQuestion在一条水平线上有\(n\)个高为\(a_i\)的矩形,求包含于这些矩形的最大子矩形面积。Solution我们定义\(L_i\)表示有\(a_i\)这个高度的一根悬线,往左最多能平移到什么位置初始化显然,\(a_i=i\)考虑转移......
  • 题解 AT_codefestival_2016_final_f【Road of the King】
    注意到当前移动到的位置并不重要,重要的是经过的点数和\(1\)所在强连通分量大小,因此把它们放进状态里:设\(f_{i,j,k}\)表示进行\(i\)次移动,经过了\(j\)个不同的点,此时\(1\)所在的强连通分量大小为\(k\)的方案数。考察下一次移动到的点的情况:没有访问过:共有\(n-j\)......
  • UVA11282 题解
    题意简述Kelly寄出去\(n\)封邀请函,但她希望只有小于等于\(m\)个人收到他们自己的邀请函(即有至少\(n-m\)个人收到了别人的邀请函)。思路形成容易发现,这道题是一个典型的错排题,我们只需要分别求出\(n-m\)个元素到\(n\)个元素的错排即可。接下来为错排的推导,我们令\(f......
  • [题解] P4755 Beautiful Pair
    P4755BeautifulPair给你一个长度为\(n\)的序列\(a\),求有多少个区间\([l,r]\)满足\(a_l\cdota_r\le\max_{i=l}^ra_i\)。\(n\le10^5,a_i\le10^9\)。首先按最大值位置分治。记当前分治区间为\([l,r]\),分治中心为\(mid\)。那么我们现在要做的就是统计跨......
  • 【题解 P4062 & P8313】 Yazid 的新生舞会&Izbori
    [COCI2021-2022#4]Izbori题目描述Malnar先生正在竞选县长,这个县一共有\(n\)栋房屋,每栋房屋里都住着一位居民。Malnar先生知道,选举的赢家不一定是最好的候选人,而是在选举前举办的宴会最好的候选人。因此,在选举前几天,他将邀请第\(l\)至\(r(l\ler)\)栋房屋内居住的居民,为......
  • 【题解】CF1891E - Brukhovich and Exams
    【题解】CF1891E-BrukhovichandExamshttps://www.luogu.com.cn/problem/CF1891E我们考虑把区间分段:若两个相邻的数不互素,中间分开;若两个相邻的数中有且仅有一个\(1\),中间分开。那么我们得到了两种区间:全\(1\)区间与无\(1\)区间。若两个相邻数在同一区间内,那么就在区间......
  • [题解] CFgym101623F Factor-Free Tree
    Factor-FreeTree当一棵二叉树中的每个节点的权值都与它所有祖先的权值互质时,我们称它为factor-freetree。给你一棵按照中序遍历的顺序的权值序列\(a\),求这个序列是否对应这一棵factor-freetree。如果是就输出每个节点的父亲。\(n\le10^5,a_i\le10^7\)。考虑怎么......
  • SP2139题解
    思路这题数据范围小,暴力就可以了。首先我们用map来统计每个人的下标,用\(bk_{i,j}\)表示第\(i\)个人第\(j\)题是否知道答案。对于每次合作交流,暴力修改就可以了,先统计出两个人的下标,假设一个为\(x\),另一个为\(y\)。然后,如果\(bk_{x,i}\)和\(bk_{y,i}\)中(\(1\lei......