首页 > 其他分享 >P6835 [Cnoi2020] 线形生物题解

P6835 [Cnoi2020] 线形生物题解

时间:2023-07-18 16:47:05浏览次数:47  
标签:题解 sum Cnoi2020 cfrac rightarrow P6835 du Sum times

P6835 [Cnoi2020] 线形生物题解

题目描述

求从 \(1\) 到 \(n+1\) 的链的期望,其中有 \(m\) 条返祖边:\(u->v\) 这条边 \(u\ge v\),等概率,求期望

Solution

这种爬楼梯的题一般求解 \(E(x\rightarrow x+1)\),则最后答案为 \(\sum_{i=1}^n E(i\rightarrow i+1)\)

我们考虑从 \(x\rightarrow x+1\),可以有多少种情况(注意,一定从 \(x\) 开始)

  • \(x\) 选择了树边,则期望步数为 \(1\) 步,概率为 \(P(树边)=\cfrac{1}{du_x+1}\),其中 \(du_x\) 为 \(x\) 的返祖边数量
  • \(x\) 选择了返祖边,则期望步数为:先走到那个点,然后再跳上来 \(1+E_{(x,y)\in G} (y\rightarrow x+1)\),概率为 \(P(返祖边)=\cfrac{1}{du_x+1}\)

当然,有 \(du_x\) 条返祖边,我们把他加起来再把概率提出来可以得到一个基础式子:

\[E(x\rightarrow x+1)=\cfrac{1}{du_x+1}\times 1 + \cfrac{1}{du_x+1} \times \sum_{(x,y)\in G} E(y\rightarrow x+1) + 1 \]

考虑到右边的 \(E\) 不是一步一步,而是多步,我们根据期望的线性性可以得到一个拆解的式子:

\[E(x\rightarrow y)=\sum_{i=x}^{y-1} E(i\rightarrow i+1) \]

将这个式子带入上边,并且设 \(f(x)=E(x\rightarrow x+1)\) 则

\[f(x)=\cfrac{1}{du_x+1} + \cfrac{1}{du_x+1} \times \sum_{(x,y) \in G} (\sum_{i=y}^x (f(i))+1) \]

将 1 拆出来合并则:

\[\begin{aligned} f(x)=&\cfrac{1}{du_x+1}+\cfrac{1}{du_x+1}\times \sum_{(x,y)\in G}\sum_{i=y}^x f(i) + \cfrac{1}{du_x+1}\times du_x\\ =&\cfrac{du_x+1}{du_x+1} +\cfrac{1}{du_x+1}\times \sum_{(x,y)\in G}\sum_{i=y}^x f(i)\\ =& 1+\cfrac{1}{du_x+1}\times \sum_{(x,y)\in G}\sum_{i=y}^x f(i) \end{aligned} \]

注意到右边也有 \(f(x)\),我们把它分离出来再用前缀和 \(Sum_x=\sum_{i=1}^x f(i)\) 优化一下:

\[f(x)=1+\cfrac{1}{du_x+1}\times \sum_{(x,y)\in G} Sum_{x-1}-Sum_{y-1} + \cfrac{1}{du_x+1}\times du_x \times f(x) \]

最后化简一下得到:

\[f(x)=du_x+1 + \sum_{(x,y)\in G} Sum_{x-1}-Sum_{y-1} \]

这是个非常完美的地递推式,写出代码:

#include <bits/stdc++.h>

using namespace std;

const int MAXN = 1e6 + 7;

typedef long long ll;

const ll Mod = 998244353;

int id, n, m;

vector <int> G[MAXN];

ll Dp[MAXN], Sum[MAXN];

int main () {
	cin >> id >> n >> m;
	for (int i = 1, u, v; i <= m; i ++) {
		cin >> u >> v; G[u].push_back(v);
	}
	for (int i = 1; i <= n; i ++) {
		Dp[i] = 1;
		for (auto v : G[i]) 
			Dp[i] = (Dp[i] + Sum[i - 1] - Sum[v - 1] + 1 + Mod) % Mod;
		Sum[i] = (Sum[i - 1] + Dp[i]) % Mod;
	}
	cout << Sum[n] << '\n';
	return 0;
}

因为每个点每条边各枚举一次,总时间复杂度为 \(O(n+m)\)

完结撒花✿✿ヽ(°▽°)ノ✿

标签:题解,sum,Cnoi2020,cfrac,rightarrow,P6835,du,Sum,times
From: https://www.cnblogs.com/Phrvth/p/17563401.html

相关文章

  • Building Bridges 题解
    BuildingBridges题目大意连接两根柱子\(i,j\)的代价是\((h_i-h_j)^2+\sum\limits_{k=j+1}^{i-1}w_k\),连接具有传递性,求将\(1,n\)连接的最小代价。思路分析斜率优化DP板题。设\(f_i\)表示考虑到前\(i\)根柱子并强制选择第\(i\)根柱子的最小代价,所求即\(f_n\)。......
  • [ABC310D] Peaceful Teams 题解
    PeacefulTeams题目大意将\(n\)个人分成\(T\)组,要求每组不能包含敌对的人,问有多少种分法。思路分析注意到\(n,T\)均很小,考虑爆搜。注意到直接枚举会枚举到分组顺序的全排列,所以可以强行嵌定大小关系去重。voiddfs(ints){if(s==n+1){for(inti=1;i<=t;......
  • NOI春季测试前模拟赛题解
    T312819命题工作直接容斥。总方案-一题出现四次-一题出现三次-一题出现两次。一题出现两次的情况略有不同,注意考虑周全。复杂度\(O(n)\)。codeT312891图上棋局有技巧的博弈论。如果当前点的所有出边均为先手必胜,那么当前点为先手必败。否则先手必胜。于是......
  • 题解 P2137 Gty的妹子树
    神奇的分块。假如没有\(2\)操作,我们可以直接用主席树解决。我们考虑将询问分块,每遍历完一块就将这一块内出现的所有修改更新。如果在块内,就把当前块之前的所有修改暴力算,当然只有修改的节点在询问的节点的子树内才会发生。具体的来说,我们可以用分块维护dfs序,并将块内的元素......
  • 题解 P4183 [USACO18JAN] Cow at Large P
    带有小trick的点分治。建议先做完弱化版再看。假如奶牛在\(u\),那么所需的最少农夫数为\(\sum\limits_{v\inson(u)}[dis(u,v)\geg_v][dis(u,fa_v)<g_{fa_v}]\)。其中\(dis(u,v)\)为\(u,v\)在树上的距离,\(g_u\)为\(u\)到离它最近的出入口的距离(BFS预处理),\(fa_u\)......
  • 题解 P9415 下楼
    不难推理出当初始绳长为\(len\),需要下降的距离为\(d\),并且满足\(d\lelen<2d\)时,最优的环套法可以只损失\(2d-len\)长度的绳子,留下\(2(len-d)\)的绳子。当\(2d\lelen\)时存在一种不损耗绳长的方法可以下到下一根钢管,即把整根绳子系成一个环,到达下面再剪断。正文:线......
  • 题解 P9437『XYGOI round1』一棵树
    换根DP。本蒟蒻最初没想到换根,把自己写自闭了...定义\(f_u\)为子树\(u\)中的每个结点走到\(u\)的贡献和,\(l_u\)为大于\(a_u\)的最小的\(10\)的幂次方数,\(sum_u\)为\(\sum\limits_{v\inson(u)}{f_v}\)。转移方程为:\(f_u=l_u\cdot\sum\limits_{v\inson(u)}{f_v}+......
  • 决策单调性优化DP 学习笔记 & P4767 [IOI2000] 邮局 题解
    0.题面题目描述高速公路旁边有一些村庄。高速公路表示为整数轴,每个村庄的位置用单个整数坐标标识。没有两个在同样地方的村庄。两个位置之间的距离是其整数坐标差的绝对值。邮局将建在一些,但不一定是所有的村庄中。为了建立邮局,应选择他们建造的位置,使每个村庄与其最近的邮局......
  • 题解 P7215
    点分治。考虑当前的分治重心的城市被完全联通。这可以用队列接解决。每次放入一种城市,就把那些城镇的父亲加入队列,如果存在城镇不在当前分治重心的联通块内,那么说明必定存在另一个分治重心能算到它,直接退出即可。剩下的和模板没有任何区别。复杂度\(O(n\logn)\)。code:#in......
  • 题解 P6329
    点分树模板题。是个神奇的算法。点分树就是将分治重心按照层级连边,每个节点父亲的联通块都包含了当前节点的联通块,且高度为\(\logn\)。可以解决不考虑树的形态的多次询问带修改的问题。对于这道题,我们可以在点分树的每个节点上记录两棵树状数组,分别与当前节点距离为\(k\)的......