最长不下降子序列问题

题目描述

给定正整数序列 $x_1 \ldots, x_n$。 1. 计算其最长不下降子序列的长度 $s$。 2. 如果每个元素只允许使用一次,计算从给定的序列中最多可取出多少个长度为 $s$ 的不下降子序列。 3. 如果允许在取出的序列中多次使用 $x_1$ 和 $x_n$(其他元素仍然只允许使用一次),则从给定序列中最多可取出多少个**不同的**长度为 $s$ 的不下降子序列。 令 $a_1, a_2, \ldots, a_s$ 为构造 $S$ 时所使用的下标,$b_1, b_2, \ldots, b_s$ 为构造 $T$ 时所使用的下标。且 $\forall i \in [1,s-1]$,都有 $a_i \lt a_{i+1}$,$b_i \lt b_{i+1}$。则 $S$ 和 $T$ **不同**,当且仅当 $\exists i \in [1,s]$,使得 $a_i \neq b_i$。

输入输出格式

输入格式


第一行有一个正整数 $n$,表示给定序列的长度。接下来的一行有 $n$ 个正整数$x_1, ..., x_n$。

输出格式


- 第 1 行是最长不下降子序列的长度 $s$。 - 第 2 行是可取出的长度为 $s$ 的不下降子序列个数。 - 第 3 行是允许在取出的序列中多次使用 $x_1$ 和 $x_n$ 时可取出的长度为 $s$ 的**不同的**不下降子序列个数。

输入输出样例

输入样例 #1

4
3 6 2 5

输出样例 #1

2
2
3

说明

$1 \le n\le 500$