atcoder#ABC234G. [ABC234G] Divide a Sequence

[ABC234G] Divide a Sequence

配点 : 600600

問題文

長さ 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 に含まれる要素の最小値と定義します。

制約

  • 1N3×1051 \leq N \leq 3 \times 10^5
  • 1Ai1091 \leq A_i \leq 10^9
  • 入力はすべて整数

入力

入力は以下の形式で標準入力から与えられる。

NN

A1A_1 A2A_2 \ldots ANA_N

出力

求めた値の総和を 998244353998244353 で割ったあまりを出力せよ。

3
1 2 3
2

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)) は順に 00, 00, 00, 22 であるため、その総和である 22 を出力します。

4
1 10 1 10
90
10
699498050 759726383 769395239 707559733 72435093 537050110 880264078 699299140 418322627 134917794
877646588

998244353998244353 で割ったあまりを出力することに注意してください。