#aBC234G. [ABC234G] Divide a Sequence

[ABC234G] Divide a Sequence

AT_abc234_g [ABC234G] Divide a Sequence

题目描述

给定一个长度为 NN 的数列 AA

AA 切分为若干个非空、连续的子序列 B1,B2,,BkB_1,B_2,\ldots,B_k 的方法共有 2N12^{N-1} 种。对于每一种切分方式,计算如下的值,并将所有切分方式下的结果求和后对 998244353998244353 取模输出:

  • i=1k (max(Bi)min(Bi))\prod_{i=1}^{k}\ (\max(B_i)-\min(B_i))

这里,对于某个子序列 Bi=(Bi,1,Bi,2,,Bi,j)B_i=(B_{i,1},B_{i,2},\ldots,B_{i,j})max(Bi)\max(B_i) 表示 BiB_i 中元素的最大值,min(Bi)\min(B_i) 表示 BiB_i 中元素的最小值。

输入格式

输入以如下格式从标准输入读入:

NN A1A_1 A2A_2 \ldots ANA_N

输出格式

输出所求值的总和对 998244353998244353 取模后的结果。

输入输出样例 #1

输入 #1

3
1 2 3

输出 #1

2

输入输出样例 #2

输入 #2

4
1 10 1 10

输出 #2

90

输入输出样例 #3

输入 #3

10
699498050 759726383 769395239 707559733 72435093 537050110 880264078 699299140 418322627 134917794

输出 #3

877646588

说明/提示

数据范围

  • 1N3×1051\leq N\leq 3\times 10^5
  • 1Ai1091\leq A_i\leq 10^9
  • 输入均为整数

样例解释 1

A=(1,2,3)A=(1,2,3) 切分为非空连续子序列的方法共有 44 种:

  • (1)(1)(2)(2)(3)(3)
  • (1)(1)(2,3)(2,3)
  • (1,2)(1,2)(3)(3)
  • (1,2,3)(1,2,3)

对于每种切分方式,i=1k (max(Bi)min(Bi))\prod_{i=1}^{k}\ (\max(B_i)-\min(B_i)) 分别为 00000022,因此总和为 22,输出 22

样例解释 3

请注意,输出时需要对 998244353998244353 取模。

由 ChatGPT 4.1 翻译