\(\mathcal{Description}\)

  Link.

  给定一棵包含 \(n\) 个点,有点权和边权的树。设当前位置 \(s\)(初始时 \(s=1\)),每次在 \(n\) 个结点内随机选择目标结点 \(t\),付出「\(s\) 到 \(t\) 的简单路径上的边权之和」\(\times\)「\(t\) 的点权」的代价,标记(可以重复标记)点 \(t\) 并把 \(s\) 置为 \(t\)。求每个点至少被标记一次时(其中 \(1\) 号结点一开始就被标记)代价之和的期望。答案对 \(998244353\) 取模。

  \(n\le10^6\)。

\(\mathcal{Solution}\)

  首先,有期望意义下的 Min-Max 容斥的公式:

\[E(\max(S))=\sum_{T\subseteq S\land T\not=\varnothing}(-1)^{|T|-1}E(\min(T))
\]

  对于本题,\(S=\{2,3,\cdots,n\}\),要求的答案等价于标记最后一个未标记点时代价的期望,那么枚举上式中的 \(T\),并设 \(|T|=m\),我们只需要对于每个 \(T\),求出从结点 \(1\) 出发,标记 \(T\) 集合内任意一个点的期望代价就行。

  考虑一个朴素的 DP:令 \(f_T(u)\) 表示现在在 \(u\) 点(\(u\) 点已标记)时,标记 \(T\) 内任意一点的期望代价。显然:

\[f_T(u)=\begin{cases}0&u\in T\\
\frac{1}n\left( \sum_{v=1}^nf_T(v)+\operatorname{dist}(u,v) \right)&u\not\in T
\end{cases}
\]

  其中 \(\operatorname{dist}(u,v)\) 即表示题意中把 \(u\) 置为 \(v\) 的代价。到此,你就可以获得 \(10\) 分的好成绩啦!


  接下来,取出一个 \(u\not\in T\) 的 \(f_T(u)\) 来研究:

\[f_T(u)=\frac{1}n\left( \sum_{v=1}^nf_T(v)+\operatorname{dist}(u,v) \right)\\
\Rightarrow nf_T(u)-\sum_{v=1}^nf_T(v)=\sum_{v=1}^n\operatorname{dist}(u,v)
\]

  令 \(s=\sum_{v\not\in T}f(v)\),\(w(u)=\sum_{v=1}^n\operatorname{dist}(u,v)\),\(C=S-T=\{c_1,c_2,\cdots,c_{n-m}\}\)(其中恒有 \(c_1=1\))列出共 \(|C|\) 个等式:

\[\left.
\begin{matrix}
nf_T(c_1)-s=w(c_1)\\
nf_T(c_2)-s=w(c_2)\\
\cdots\\
nf_T(c_{n-m})-s=w(c_{n-m})
\end{matrix}
\right\}n-m\text{ equations in total.}
\]

  左右分别相加得到:

\[ns-(n-m)s=\sum_{v\not\in T}w(v)\\
\Rightarrow s=\frac{\sum_{v\not\in T}w(v)}{m}
\]

  于是乎,要求的 \(f_T(1)\) 就有:

\[f_T(c_1)=\frac{s+w(1)}{n}
\]

  此后,把 \(f_T(1)\) 带入答案的式子里:

\[\begin{aligned}
&\sum_{T\subseteq S\land T\not=\varnothing}(-1)^{|T|-1}f_T(1)\\
=&\sum_{T\subseteq S\land T\not=\varnothing}(-1)^{|T|-1}\left( \frac{w(1)}{n}+\frac{\sum_{u\not\in T}w(u)}{n|T|} \right)\\
=&\frac{1}n\sum_{m=1}^{n-1}(-1)^{m-1}\left[ \binom{n-1}mw(1)+\frac{1}m\sum_{T\subseteq S\land|T|=m}\sum_{u\not\in T}w(u) \right]
\end{aligned}
\]

  令 \(g(m)=\sum_{T\subseteq S\land|T|=m}\sum_{v\not\in T}w(v)\),单独考虑结点 \(1\),它必然不属于 \(T\);再考虑其他结点的贡献次数,可以得出:

\[g(m)=\binom{n-1}{m}w(1)+\binom{n-2}m\sum_{u=2}^nw(u)
\]

  最后,只需要求出 \(\sum_{u=1}^nw(u)\)。分别考虑每条边 \((u,v,b)\in E\) 的贡献。将这条边删去,记此时 \(u\) 所在联通块的结点个数为 \(p_u\),结点点权之和为 \(q_u\),\(v\) 同理。则:

\[\sum_{u=1}^nw(u)=\sum_{(u,v)\in E}b(u,v)(p_uq_v+p_vq_u)
\]

  综上,求出这一系列式子,问题就以 \(\mathcal O(n)\) 的复杂度解决啦!

\(\mathcal{Code}\)

/* Clearink */

#include <cstdio>

inline char fgc () {
static char buf[1 << 17], *p = buf, *q = buf;
return p == q && ( q = buf + fread ( p = buf, 1, 1 << 17, stdin ), p == q ) ? EOF : *p++;
} inline int rint () {
int x = 0; char s = fgc ();
for ( ; s < '0' || '9' < s; s = fgc () );
for ( ; '0' <= s && s <= '9'; s = fgc () ) x = x * 10 + ( s ^ '0' );
return x;
} const int MAXN = 1e6, MOD = 998244353;
int n, ecnt, head[MAXN + 5], val[MAXN + 5], fac[MAXN + 5], ifac[MAXN + 5];
int fa[MAXN + 5], siz[MAXN + 5], sum[MAXN + 5], dist[MAXN + 5]; // dist[i]==dist(1,i).
int g[MAXN + 5]; inline int mul ( const long long a, const int b ) { return a * b % MOD; }
inline int sub ( int a, const int b ) { return ( a -= b ) < 0 ? a + MOD : a; }
inline int add ( int a, const int b ) { return ( a += b ) < MOD ? a : a - MOD; }
inline void addeq ( int& a, const int b ) { ( a += b ) >= MOD && ( a -= MOD, 0 ); } struct Edge { int to, cst, nxt; } graph[MAXN * 2 + 5]; inline void link ( const int s, const int t, const int c ) {
graph[++ecnt] = { t, c, head[s] };
head[s] = ecnt;
} inline int qkpow ( int a, int b ) {
int ret = 1;
for ( ; b; a = mul ( a, a ), b >>= 1 ) ret = mul ( ret, b & 1 ? a : 1 );
return ret;
} inline void init () {
fac[0] = 1;
for ( int i = 1; i <= n; ++i ) fac[i] = mul ( i, fac[i - 1] );
ifac[n] = qkpow ( fac[n], MOD - 2 );
for ( int i = n - 1; ~i; -- i ) ifac[i] = mul ( i + 1ll, ifac[i + 1] );
} inline int inv ( const int x ) { return mul ( fac[x - 1], ifac[x] ); } inline int comb ( const int n, const int m ) {
return n < m ? 0 : mul ( fac[n], mul ( ifac[m], ifac[n - m] ) );
} inline void dfs ( const int u ) {
siz[u] = 1, sum[u] = val[u];
for ( int i = head[u], v; i; i = graph[i].nxt ) {
if ( ( v = graph[i].to ) ^ fa[u] ) {
dist[v] = add ( dist[fa[v] = u], graph[i].cst );
dfs ( v ), siz[u] += siz[v], addeq ( sum[u], sum[v] );
}
}
} int main () {
n = rint ();
int vs = 0;
for ( int i = 1; i <= n; ++i ) vs = add ( vs, val[i] = rint () );
for ( int i = 1, u, v, w; i < n; ++i ) {
u = rint (), v = rint (), w = rint ();
link ( u, v, w ), link ( v, u, w );
}
init (), dfs ( 1 );
int S = 0;
for ( int u = 1; u <= n; ++u ) {
for ( int i = head[u], v; i; i = graph[i].nxt ) {
if ( ( v = graph[i].to ) ^ fa[u] ) {
addeq ( S, mul ( graph[i].cst,
add ( mul ( siz[v], sub ( vs, sum[v] ) ),
mul ( n - siz[v], sum[v] ) ) ) );
}
}
}
for ( int i = 2; i <= n; ++i ) addeq ( g[n - 1], mul ( val[i], dist[i] ) );
for ( int i = n - 2; i; --i ) {
g[i] = add ( mul ( comb ( n - 1, i ), g[n - 1] ),
mul ( comb ( n - 2, i ), sub ( S, g[n - 1] ) ) );
}
int ans = 0;
for ( int i = 1; i < n; ++i ) {
ans = ( i & 1 ? add : sub )( ans,
add ( mul ( comb ( n - 1, i ), g[n - 1] ), mul ( inv ( i ), g[i] ) ) );
}
printf ( "%d\n", mul ( ans, inv ( n ) ) );
return 0;
}

Solution -「GLR-R2」教材运送的更多相关文章

  1. Solution -「ARC 104E」Random LIS

    \(\mathcal{Description}\)   Link.   给定整数序列 \(\{a_n\}\),对于整数序列 \(\{b_n\}\),\(b_i\) 在 \([1,a_i]\) 中等概率 ...

  2. Solution -「CTS 2019」「洛谷 P5404」氪金手游

    \(\mathcal{Description}\)   Link.   有 \(n\) 张卡牌,第 \(i\) 张的权值 \(w_i\in\{1,2,3\}\),且取值为 \(k\) 的概率正比于 \ ...

  3. Solution -「BZOJ 3812」主旋律

    \(\mathcal{Description}\)   Link.   给定含 \(n\) 个点 \(m\) 条边的简单有向图 \(G=(V,E)\),求 \(H=(V,E'\subseteq E)\ ...

  4. Solution -「CF 1342E」Placing Rooks

    \(\mathcal{Description}\)   Link.   在一个 \(n\times n\) 的国际象棋棋盘上摆 \(n\) 个车,求满足: 所有格子都可以被攻击到. 恰好存在 \(k\ ...

  5. Solution -「CERC 2016」「洛谷 P3684」机棚障碍

    \(\mathcal{Description}\)   Link.   给一个 \(n\times n\) 的网格图,每个点是空格或障碍.\(q\) 次询问,每次给定两个坐标 \((r_1,c_1), ...

  6. Solution -「CF 793G」Oleg and Chess

    \(\mathcal{Description}\)   Link.   给一个 \(n\times n\) 的棋盘,其中 \(q\) 个互不重叠的子矩阵被禁止放棋.问最多能放多少个互不能攻击的车.   ...

  7. Solution -「简单 DP」zxy 讲课记实

    魔法题位面级乱杀. 「JOISC 2020 Day4」治疗计划 因为是不太聪明的 Joker,我就从头开始理思路了.中途也会说一些和 DP 算法本身有关的杂谈,给自己的冗长题解找借口. 首先,治疗方案 ...

  8. Solution -「基环树」做题记录

    写的大多只是思路,比较简单的细节和证明过程就不放了,有需者自取. 基环树简介 简单说一说基环树吧.由名字扩展可得这是一类以环为基础的树(当然显然它不是树. 通常的表现形式是一棵树再加一条非树边,把图画 ...

  9. Solution -「WC 2022」秃子酋长

    \(\mathscr{Description}\)   Link. (It's empty temporarily.)   给定排列 \(\{a_n\}\),\(q\) 次询问,每次给出 \([l,r ...

随机推荐

  1. vue将HTML字符串解析为HTML标签

    如果返回的数据是html标签字符串的话,在vue里要通过v-html来渲染 <div v-html="rawHtml"></div> //v-html=&q ...

  2. Vue-cli代理解决跨域问题

    使用vue-cli调接口的时候,总是会出现垮与问题,因为vue的localhost与访问域名不一致导致.而这一点,开发者显然也想到了,故而在vuejs-templates,也就是vue-cli的使用的 ...

  3. SYCOJ906瑞士轮

    题目-瑞士轮 (shiyancang.cn) 模拟题 #include<bits/stdc++.h> using namespace std; const int N=1e5+520; i ...

  4. 机器学习|线性回归算法详解 (Python 语言描述)

    原文地址 ? 传送门 线性回归 线性回归是一种较为简单,但十分重要的机器学习方法.掌握线性的原理及求解方法,是深入了解线性回归的基本要求.除此之外,线性回归也是监督学习回归部分的基石. 线性回归介绍 ...

  5. Nginx高级模块学习

    Nginx的rewrite规则 实现url重写一级重定向 使用场景: 1.URL访问跳转,支持开发设计 页面跳转.兼容性支持.展示效果 2.SEO优化 3.维护 后台维护.流量转发等 4.安全 配置语 ...

  6. ubuntu18.04下取消中键复制粘贴功能

    Q: armlinux开发,主机采用ubuntu18.04操作系统,使用过程中关于鼠标中键有如下操作现象, 操作: 1.选中文本, 2.将鼠标光标定位到要插入的位置 3.按下鼠标中键 现象:将自动复制 ...

  7. 《剑指offer》面试题54. 二叉搜索树的第k大节点

    问题描述 给定一棵二叉搜索树,请找出其中第k大的节点.   示例 1: 输入: root = [3,1,4,null,2], k = 1 3 / \ 1 4 \   2 输出: 4 示例 2: 输入: ...

  8. JQuery选择器的使用和分类

    jQuery选择器 id选择器格式 $("#box") //获取标签里的id是box的标签 类选择器格式 $(".a") //获取标签里的类名是a的标签 标签选 ...

  9. vue学习10-计算属性

    计算属性 1 <!DOCTYPE html> 2 <html lang='en'> 3 <head> 4 <meta charset='UTF-8'> ...

  10. gin框架中全局跨域请求处理设置

    跨域访问的问题 OPTIONS请求 全局跨域访问中间件 // 跨域访问:cross origin resource share func Cors() gin.HandlerFunc { return ...