A106059.[GESP202603 八级] 子图最短路

普及+/提高

GESP

通过率:0%

时间限制:1.00s

内存限制:128MB

题目描述

给定包含 nn 个结点 mm 条边的带权无向图 GG,结点依次以 1,2,,n1, 2, \dots, n 编号。第 ii (1im1 \le i \le m) 条边连接编号为 uiu_iviv_i 的两个结点,权值为 wiw_i

对于指定的 1rn1 \le \ell \le r \le n,按以下方式构造图 GG 的子图 G(,r)G(\ell, r)

  • 保留 GG 中编号在区间 [,r][\ell, r] 中的结点。删去其它编号不在 [,r][\ell, r] 中的结点以及与之相连的边。剩余的结点和边构成子图 G(,r)G(\ell, r)

对于 G(,r)G(\ell, r) 中的任意结点 u,vu, v 应有 u,vr\ell \le u, v \le r。记 u,vu, v 在子图 G(,r)G(\ell, r) 上的最短距离为 d(,r,u,v)d(\ell, r, u, v)。特殊地,若 u,vu, v 在子图 G(,r)G(\ell, r) 上不连通,则认为 d(,r,u,v)=0d(\ell, r, u, v) = 0

你需要求出 =1nr=nu=rv=urd(,r,u,v)\sum_{\ell=1}^{n} \sum_{r=\ell}^{n} \sum_{u=\ell}^{r} \sum_{v=u}^{r} d(\ell, r, u, v)10910^9 取模的结果。

  • 题目中的英文字母 ll 使用了特殊写法 \ell,以避免英文字母 ll 与数字 11 混淆。

输入格式

第一行,两个正整数 n,mn, m,表示结点数与边数。

接下来 mm 行,第 ii (1im1 \le i \le m) 行包含三个正整数 ui,vi,wiu_i, v_i, w_i,表示一条连接结点 ui,viu_i, v_i 的权值为 wiw_i 的边。

输出格式

输出一行,一个整数,表示 =1nr=nu=rv=urd(,r,u,v)\sum_{\ell=1}^{n} \sum_{r=\ell}^{n} \sum_{u=\ell}^{r} \sum_{v=u}^{r} d(\ell, r, u, v)10910^9 取模的结果。

输入输出样例

  • 输入#1

    3 2
    1 2 1
    2 3 2
    

    输出#1

    9
    
  • 输入#2

    4 6
    1 2 100
    2 3 100
    3 4 100
    1 3 10
    2 4 10
    1 4 1
    

    输出#2

    784
    

说明/提示

对于所有测试点,保证 2n1002 \le n \le 1002mn(n1)22 \le m \le \frac{n(n-1)}{2}1ui,vin1 \le u_i, v_i \le n1wi1061 \le w_i \le 10^6。图中可能存在重边。

首页