#aBC159F. [ABC159F] Knapsack for All Segments

[ABC159F] Knapsack for All Segments

AT_abc159_f [ABC159F] Knapsack for All Segments

题目描述

给定一个长度为 NN 的整数序列 A1,A2,,ANA_1, A_2, \ldots, A_N 和一个正整数 SS
对于所有满足 1LRN1 \leq L \leq R \leq N 的整数对 (L,R)(L, R),定义 f(L,R)f(L, R) 如下:

  • f(L,R)f(L, R) 表示满足 Lx1<x2<<xkRL \leq x_1 < x_2 < \cdots < x_k \leq RAx1+Ax2++Axk=SA_{x_1} + A_{x_2} + \cdots + A_{x_k} = S 的整数序列 (x1,x2,,xk)(x_1, x_2, \ldots, x_k) 的个数。

请计算所有满足 1LRN1 \leq L \leq R \leq N 的整数对 (L,R)(L, R)f(L,R)f(L, R) 之和。由于答案可能非常大,请输出其对 998244353998244353 取模的结果。

输入格式

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

NN SS A1A_1 A2A_2 \ldots ANA_N

输出格式

输出所有 f(L,R)f(L, R) 之和对 998244353998244353 取模的结果。

输入输出样例 #1

输入 #1

3 4
2 2 4

输出 #1

5

输入输出样例 #2

输入 #2

5 8
9 9 9 9 9

输出 #2

0

输入输出样例 #3

输入 #3

10 10
3 1 4 1 5 9 2 6 5 3

输出 #3

152

说明/提示

限制条件

  • 输入均为整数。
  • 1N30001 \leq N \leq 3000
  • 1S30001 \leq S \leq 3000
  • 1Ai30001 \leq A_i \leq 3000

样例解释 1

可以分别计算如下,和为 55

  • f(1,1)=0f(1,1) = 0
  • f(1,2)=1f(1,2) = 1(仅有 (1,2)(1, 2) 这一种情况)
  • f(1,3)=2f(1,3) = 2(1,2)(1, 2)(3)(3) 两种情况)
  • f(2,2)=0f(2,2) = 0
  • f(2,3)=1f(2,3) = 1(仅有 (3)(3) 这一种情况)
  • f(3,3)=1f(3,3) = 1(仅有 (3)(3) 这一种情况)

由 ChatGPT 4.1 翻译