A91991.「ZJOI2016」线段树

省选/NOI-

通过率:0%

时间限制:1.00s

内存限制:256MB

题目描述

小 Yuuka 遇到了一个题目:有一个序列 a1,a2,,ana_1, a_2, \ldots , a_n,对其进行qq次操作,每次把一个区间内的数改成区间内的最大值,问最后每个数是多少。

小 Yuuka 很快地就使用了线段树解决了这个问题。于是充满智慧的小 Yuuka 想,如果操作是随机的,即在这 qq 次操作中每次等概率随机地选择一个区间 [l,r][l,r] (1lrn)(1 \leq l \leq r \leq n),然后将这个区间内的数改成区间内最大值(注意这样的区间共有 n(n+1)2\frac{n(n+1)}{2} 个),最后每个数的期望大小是多少呢?小 Yuuka 非常热爱随机,所以她给出的输入序列也是随机的(随机方式见数据规模和约定)。对于每个数,输出它的期望乘 (n(n+1)2)q(\frac{n(n+1)}{2})^q 再对 109+710^9+7 取模的值。

输入格式

第一行包含两个正整数 n,qn,q,表示序列里数的个数和操作的个数。

接下来一行,包含 nn 个非负整数 a1,a2,,ana_1, a_2, \ldots, a_n

输出格式

输出共一行,包含 nn 个整数,表示每个数的答案

输入输出样例

  • 输入#1

    5 5
    1 5 2 3 4

    输出#1

    3152671 3796875 3692207 3623487 3515626

说明/提示

对于所有的测试数据,保证序列中数的大小不超过 10910^9,即 ai109a_i≤10^9,并且每个数是 0010910^9 之间的随机整数。

测试点编号 nn qq
11 5\le 5 $\le 5 $
22 8\le 8 $\le 400 $
33 12\le 12 $\le 400 $
44 30\le 30 $\le 400 $
55 50\le 50 $\le 400 $
66 100\le 100 $\le 400 $
77 100\le 100 $\le 400 $
88 400\le 400 $\le 400 $
99 400\le 400 $\le 400 $
1010 400\le 400 $\le 400 $
首页