概率能用$DP$来做的理论基础:
$\ \ \ $期望的线性性质:$E(ax+by)=aE(X)+bE(Y)$
状态表示:$f[i]$表示从$i$走到$n$的期望
$$状态转移方程:f[i] = \sum_{i=1}^{k}\frac{1}{k}(w[i] + f(S[i)$$
#include <iostream>
#include <cstring>
using namespace std;
const int N = 100010 , M = 2 * N;
double f[N];
int e[M] , ne[M] , w[M] , h[N] , idx;
int n ,m;
int d[N];
void add(int a , int b , int c)
{
e[idx] = b , ne[idx] = h[a] ; w[idx] = c , h[a] = idx++;
}
double dp(int u)//记忆化搜索
{
if(f[u] >= 0) return f[u];
f[u] = 0;
for(int i = h[u] ; ~i ; i = ne[i])
{
int j = e[i];
f[u] += (w[i] + dp(j)) / d[u];
}
return f[u];
}
int main()
{
cin >> n >> m;
memset(h , -1 , sizeof h);
while(m--)
{
int a , b , c;
cin >> a >> b >> c;
add(a , b , c);
d[a]++;
}
memset(f , -1 , sizeof f);//初始化成一个不存在的数
printf("%.2lf\n" , dp(1));
return 0;
}
。
az