题目背景
白王正在挑选容器。
题目描述
白王制造了 n 个容器,并将它们排成了一队,从左到右依次编号为 1∼n。第 i 个容器的强度为 ai,保证 ai 互不相同。为了挑选出最纯粹的容器,白王会进行 n−1 轮操作,每轮操作中,他会等概率随机挑选两个 位置相邻 且 未被击倒 的容器,令它们进行决斗,在一次决斗中,强度较小的容器将会被击倒并移出队列。
显然最后留下的是强度最大的容器,但是,可怜的容器们很想知道自己能够活多久,于是,它们请你对每个容器求出它存活轮数的期望。答案对 998244353 取模。
一个容器的存活轮数为最大的非负整数 x<n 满足它在第 x 轮未被击倒。
两个容器 i 和 j 位置相邻当且仅当不存在 k 满足 i<k<j 且 k 号容器未被击倒。
输入格式
第一行一个整数 n。
第二行 n 个整数 a1,a2,⋯,an,意义见题目描述。
输出格式
一行 n 个整数,第 i 个整数表示第 i 个容器的存活轮数的期望。为了避免浮点误差,保证答案可以表示为最简分数 qp,你只需要输出一个 x(0≤x<998244353) 使得 qx≡p(mod998244353)。
3
3 1 2
2 0 1
3
1 2 3
499122177 499122177 2
5
1 4 2 3 5
499122178 249561091 665496236 582309207 4
提示
样例解释
在第一组样例中,第一个容器无论如何不可能被击倒,第二个容器在第一轮一定会被击倒,第三个容器第一轮一定不被击倒,第二轮一定被击倒。
第二组样例的真实答案为 21,21,2。
数据范围
对于所有测试点,保证 1≤n≤50,1≤ai≤n,ai 两两不同。
Subtask 1 (2 pts) n≤2。
Subtask 2 (23 pts) n≤6。
Subtask 3 (31 pts) n≤18。
Subtask 4 (19 pts) ai=i。
Subtask 5 (25 pts) 无特殊限制。
提示
如果你不知道怎么对分数取模,可以参考这里。