結果
問題 | No.1307 Rotate and Accumulate |
ユーザー | tpyneriver |
提出日時 | 2020-12-04 14:28:41 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 433 ms / 5,000 ms |
コード長 | 3,784 bytes |
コンパイル時間 | 318 ms |
コンパイル使用メモリ | 82,072 KB |
実行使用メモリ | 185,972 KB |
最終ジャッジ日時 | 2024-09-15 00:46:47 |
合計ジャッジ時間 | 9,462 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 19 |
ソースコード
import sys readline = sys.stdin.readline import sys readline = sys.stdin.readline MOD = 998244353 def frac(limit): frac = [1]*limit for i in range(2,limit): frac[i] = i * frac[i-1]%MOD fraci = [None]*limit fraci[-1] = pow(frac[-1], MOD -2, MOD) for i in range(-2, -limit-1, -1): fraci[i] = fraci[i+1] * (limit + i + 1) % MOD return frac, fraci frac, fraci = frac(1341398) MOD = 998244353 pr = 3 LS = 20 class NTT: def __init__(self): self.N0 = 1<<LS omega = pow(pr, (MOD-1)//self.N0, MOD) omegainv = pow(omega, MOD-2, MOD) self.w = [0]*(self.N0//2) self.winv = [0]*(self.N0//2) self.w[0] = 1 self.winv[0] = 1 for i in range(1, self.N0//2): self.w[i] = (self.w[i-1]*omega)%MOD self.winv[i] = (self.winv[i-1]*omegainv)%MOD used = set() for i in range(self.N0//2): if i in used: continue j = 0 for k in range(LS-1): j |= (i>>k&1) << (LS-2-k) used.add(j) self.w[i], self.w[j] = self.w[j], self.w[i] self.winv[i], self.winv[j] = self.winv[j], self.winv[i] def _fft(self, A): M = len(A) bn = 1 hbs = M>>1 while hbs: for j in range(hbs): A[j], A[j+hbs] = A[j] + A[j+hbs], A[j] - A[j+hbs] if A[j] > MOD: A[j] -= MOD if A[j+hbs] < 0: A[j+hbs] += MOD for bi in range(1, bn): wi = self.w[bi] for j in range(bi*hbs*2, bi*hbs*2+hbs): A[j], A[j+hbs] = (A[j] + wi*A[j+hbs])%MOD, (A[j] - wi*A[j+hbs])%MOD bn <<= 1 hbs >>= 1 def _ifft(self, A): M = len(A) bn = M>>1 hbs = 1 while bn: for j in range(hbs): A[j], A[j+hbs] = A[j] + A[j+hbs], A[j] - A[j+hbs] if A[j] > MOD: A[j] -= MOD if A[j+hbs] < 0: A[j+hbs] += MOD for bi in range(1, bn): winvi = self.winv[bi] for j in range(bi*hbs*2, bi*hbs*2+hbs): A[j], A[j+hbs] = (A[j] + A[j+hbs])%MOD, winvi*(A[j] - A[j+hbs])%MOD bn >>= 1 hbs <<= 1 def convolve(self, A, B): LA = len(A) LB = len(B) LC = LA+LB-1 M = 1<<(LC-1).bit_length() A += [0]*(M-LA) B += [0]*(M-LB) self._fft(A) self._fft(B) C = [0]*M for i in range(M): C[i] = A[i]*B[i]%MOD self._ifft(C) minv = pow(M, MOD-2, MOD) for i in range(LC): C[i] = C[i]*minv%MOD return C[:LC] return C def inverse(self, A): LA = len(A) dep = (LA-1).bit_length() M = 1<<dep A += [0]*(M-LA) g = [pow(A[0], MOD-2, MOD)] for n in range(dep): dl = 1<<(n+1) f = A[:dl] fg = self.convolve(f, g[:])[:dl] fgg = self.convolve(fg, g[:])[:dl] ng = [None]*dl for i in range(dl//2): ng[i] = (2*g[i]-fgg[i])%MOD for i in range(dl//2, dl): ng[i] = MOD-fgg[i] g = ng[:] return g[:LA] def integral(self, A): A = [1] + [A[i]*fraci[i+2]%MOD for i in range(len(A))] N, Q = map(int, readline().split()) A = list(map(int, readline().split())) R = list(map(int, readline().split())) Nt = NTT() table = [0]*N for r in R: table[(N-r)%N] += 1 B = Nt.convolve(table, A) ans = [0]*N for i in range(len(B)): ans[i%N] += B[i] print(*ans)