A85327.「THUPC 2023」百合

提高+/省选-

通过率:0%

时间限制:2.00s

内存限制:512MB

题目描述

你落在一个巨大的葡萄架上,上面一共有 2k2^k 朵百合花和 mm 条葡萄藤。其中,百合花编号为 002k12^k-1 的整数,第 ii 条葡萄藤连接了编号为 xi,yix_i, y_i 的百合花。

你可以花费 cic_i 的时间通过第 ii 条葡萄藤,也就是从 xix_i 走到 yiy_i,或者反过来;还可以花费 aka_k 的时间从 xx 闪现到 yy,其中 x,yx, y 是任意两朵百合花,kk 是它们在二进制表示下不同的比特数。例如,33 的二进制表示是 01101155 的二进制表示是 101101,它们有两位不同,因此从 33 闪现到 55 花费的时间是 a2a_2

假设你恰好落在编号为 ss 的百合花上,求从 ss 出发到每一朵百合花所需要的最短时间。

输入格式

第一行包含三个正整数 k,m,sk,m,s,其含义如题目描述。

第二行包含 kk 个非负整数 aia_i1ik1 \leq i \leq k),其含义如题目描述。

33 至第 (m+2)(m+2) 行每行三个非负整数 xi,yi,cix_i,y_i,c_i1im1 \leq i \leq m),其含义如题目描述。

输出格式

输出一行 2k2^k 个数 DiD_i0i2k10 \leq i \leq 2^k-1),空格隔开,其中 DiD_i 表示从 ssii 的最短时间。

输入输出样例

  • 输入#1

    3 6 2
    17 14 11 
    0 2 3
    4 2 9
    2 2 1
    2 2 6
    7 0 5
    4 2 9
    

    输出#1

    3 14 0 17 9 11 17 8 

说明/提示

保证 k17,m2×105,0s,xi,yi2k1,0ai,ci2301k \leq 17,m \leq 2\times10^5, 0 \leq s,x_i,y_i \leq 2^k-1, 0 \leq a_i, c_i \leq 2^{30}-1

首页