結果

問題 No.2215 Slide Subset Sum
ユーザー Caiiiiiiii
提出日時 2025-09-12 17:47:43
言語 C++17
(gcc 13.3.0 + boost 1.87.0)
結果
WA  
実行時間 -
コード長 841 bytes
コンパイル時間 10,768 ms
コンパイル使用メモリ 211,872 KB
実行使用メモリ 87,772 KB
最終ジャッジ日時 2025-09-12 18:04:33
合計ジャッジ時間 28,649 ms
ジャッジサーバーID
(参考情報)
judge2 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 2
other AC * 8 WA * 27 RE * 10
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <bits/stdc++.h>

using LL = long long;

const int N = 1e5 + 7;
const int K = 100 + 7;
const int MOD = 998244353;

int n, m, k;
int f[N][K], g[N][K], a[N];

void dp(int *f, int *g, int x) {
  for(int i = 0; i < k; ++i)
    f[i] = (g[i] + g[(i + k - x) % k]) % MOD;
}

int main() {

  scanf("%d%d%d", &n, &m, &k);
  for(int i = 1; i <= n; ++i)
    scanf("%d", &a[i]);

  f[0][0] = g[0][0] = 1;
  for(int i = 1; i < m; ++i)
    dp(f[i], f[i - 1], a[i]);
  for(int i = m; i <= n; ++i) {
    int p = (i - 1) % m;
    dp(f[p + 1], f[p], a[i]);
    if(i % m == 1)
      for(int j = 1; j < m; ++j)
	dp(g[j], g[j - 1], a[i - j]);
    int ans = (MOD - 1 + f[p + 1][0] * g[m - p - 1][0]) % MOD;
    for(int i = 1; i < k; ++i)
      ans = (ans + 1LL * f[p + 1][i] * g[m - p - 1][k - i]) % MOD;
    printf("%d\n", ans);
  }    
  
  return 0;
}
0