纯粹容器

题目背景

白王正在挑选容器。

题目描述

白王制造了 $n$ 个容器,并将它们排成了一队,从左到右依次编号为 $1 \sim n$。第 $i$ 个容器的**强度**为 $a_i$,保证 $a_i$ 互不相同。为了挑选出最纯粹的容器,白王会进行 $n-1$ 轮操作,每轮操作中,他会等概率随机挑选两个 **位置相邻** 且 **未被击倒** 的容器,令它们进行决斗,在一次决斗中,强度较小的容器将会被击倒并移出队列。 显然最后留下的是强度最大的容器,但是,可怜的容器们很想知道自己能够活多久,于是,它们请你对每个容器求出它存活轮数的期望。答案对 $998244353$ 取模。 一个容器的存活轮数为最大的非负整数 $x < n$ 满足它在第 $x$ 轮未被击倒。 两个容器 $i$ 和 $j$ 位置相邻当且仅当不存在 $k$ 满足 $i<k<j$ 且 $k$ 号容器未被击倒。

输入输出格式

输入格式


第一行一个整数 $n$。 第二行 $n$ 个整数 $a_1, a_2,\cdots,a_n$,意义见题目描述。

输出格式


一行 $n$ 个整数,第 $i$ 个整数表示第 $i$ 个容器的存活轮数的期望。为了避免浮点误差,保证答案可以表示为最简分数 $\frac{p}{q}$,你只需要输出一个 $x (0 \leq x < 998244353)$ 使得 $qx \equiv p \pmod {998244353}$。

输入输出样例

输入样例 #1

3
3 1 2

输出样例 #1

2 0 1

输入样例 #2

3
1 2 3

输出样例 #2

499122177 499122177 2

输入样例 #3

5
1 4 2 3 5

输出样例 #3

499122178 249561091 665496236 582309207 4

说明

#### 样例解释 在第一组样例中,第一个容器无论如何不可能被击倒,第二个容器在第一轮一定会被击倒,第三个容器第一轮一定不被击倒,第二轮一定被击倒。 第二组样例的真实答案为 $\frac{1}{2}$,$\frac{1}{2}$,$2$。 --- #### 数据范围 对于所有测试点,保证 $1 \leq n \leq 50$,$1 \leq a_i \leq n$,$a_i$ 两两不同。 $\text{Subtask 1 (2 pts)}$ $n \leq 2$。 $\text{Subtask 2 (23 pts)}$ $n \leq 6$。 $\text{Subtask 3 (31 pts)}$ $n \leq 18$。 $\text{Subtask 4 (19 pts)}​$ $a_i = i$。 $\text{Subtask 5 (25 pts)}$ 无特殊限制。 --- #### 提示 如果你不知道怎么对分数取模,可以参考[这里](https://www.luogu.com.cn/problem/P3811)。