結果
問題 |
No.2215 Slide Subset Sum
|
ユーザー |
|
提出日時 | 2023-02-11 00:55:22 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 831 ms / 3,000 ms |
コード長 | 1,482 bytes |
コンパイル時間 | 1,643 ms |
コンパイル使用メモリ | 170,284 KB |
実行使用メモリ | 164,196 KB |
最終ジャッジ日時 | 2024-07-07 18:17:54 |
合計ジャッジ時間 | 15,313 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 45 |
コンパイルメッセージ
main.cpp: In function 'int32_t main()': main.cpp:58:18: warning: structured bindings only available with '-std=c++17' or '-std=gnu++17' [-Wc++17-extensions] 58 | auto [l,u]=v[pos]; | ^
ソースコード
#include <bits/stdc++.h> using namespace std; #define int long long const int p=998244353; int n,m,k; array<int,100> v; void add(array<int,100>& u,int x) { for(int i=0;i<k;++i) { v[(i+x)%k]=u[i]; } for(int i=0;i<k;++i) { u[i]+=v[i]; if(u[i]>=p) u[i]-=p; } } int f(array<int,100> u,array<int,100> v) { int ans=u[0]*v[0];ans%=p; for(int i=1;i<k;++i) { ans+=u[i]*v[k-i];ans%=p; } return ans; } int32_t main() { ios_base::sync_with_stdio(false);cin.tie(0);cout.tie(0); cin>>n>>m>>k; int a[n+1];for(int i=0;i<n;++i) {cin>>a[i];} a[n]=0; int ans[n]={0}; for(int i=m;i<=n;i+=m) { array<int,100> u; for(int i=0;i<100;++i) u[i]=0; u[0]=1; vector<pair<int,array<int,100> > > v(m+1); int sz=0; for(int l=i;l>=max(0LL,i-m);l--) { v[sz++]={l,u}; if(l>=1) add(u,a[l-1]); } array<int,100> d,d1; for(int i=0;i<100;++i) d1[i]=0; d1[0]=1; for(int r=i;r<=min(n,i+m);++r) { if(r!=i) { add(d1,a[r-1]); } d=d1; int pos=(i-r+m); auto [l,u]=v[pos]; while(l>r-m) { add(d,a[l-1]); --l; } ans[l]=f(d,u); } } for(int i=0;i<=n-m;++i) { cout<<(ans[i]+p-1)%p<<'\n'; } return 0; }