結果
問題 | No.1857 Gacha Addiction |
ユーザー |
|
提出日時 | 2022-02-25 21:48:58 |
言語 | PyPy3 (7.3.15) |
結果 |
MLE
|
実行時間 | - |
コード長 | 3,039 bytes |
コンパイル時間 | 167 ms |
コンパイル使用メモリ | 82,576 KB |
実行使用メモリ | 873,744 KB |
最終ジャッジ日時 | 2024-07-03 16:34:43 |
合計ジャッジ時間 | 8,585 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 WA * 2 MLE * 1 |
other | MLE * 1 -- * 42 |
ソースコード
mod = 998244353omega = pow(3,119,mod)rev_omega = pow(omega,mod-2,mod)N = 2*10**5g1 = [1]*(N+1) # 元テーブルg2 = [1]*(N+1) #逆元テーブルinv = [1]*(N+1) #逆元テーブル計算用テーブルfor i in range( 2, N + 1 ):g1[i]=( ( g1[i-1] * i ) % mod )inv[i]=( ( -inv[mod % i] * (mod//i) ) % mod )g2[i]=( (g2[i-1] * inv[i]) % mod )inv[0]=0def _ntt(f,L,reverse=False):F=[f[i] for i in range(L)]n = L.bit_length() - 1base = omegaif reverse:base = rev_omegaif not n:return Fsize = 2**nwj = pow(base,2**22,mod)res = [0]*2**nfor i in range(n,0,-1):use_omega = pow(base,2**(22+i-n),mod)res = [0]*2**nsize //= 2w = 1for j in range(0,L//2,size):for a in range(size):res[a+j] = (F[a+2*j] + w * F[a+size+2*j]) % modt = (w * wj) % modres[L//2+a+j] = (F[a+2*j] + t * F[a+size+2*j]) % modw = (w * use_omega) % modF = resreturn resdef ntt(f,L=0):l = len(f)if not L:L = 1<<((l-1).bit_length())while len(f)<L:f.append(0)f=f[:L]F = _ntt(f,L)return Fdef intt(f,L=0):l = len(f)if not L:L = 1<<((l-1).bit_length())while len(f)<L:f.append(0)f=f[:L]F = _ntt(f,L,reverse=True)inv = pow(L,mod-2,mod)for i in range(L):F[i] *= invF[i] %= modreturn Fdef convolve(f,g,limit):l = len(f)+len(g)-1L = 1<<((l-1).bit_length())F = ntt(f,L)G = ntt(g,L)H = [(F[i] * G[i]) % mod for i in range(L)]h = intt(H,L)return h[:limit]class SegmentTree:def __init__(self, init_val, segfunc, ide_ele):n = len(init_val)self.segfunc = segfuncself.ide_ele = ide_eleself.num = 1 << (n - 1).bit_length()self.tree = [ide_ele] * 2 * self.numself.size = nfor i in range(n):self.tree[self.num + i] = init_val[i]for i in range(self.num - 1, 0, -1):self.tree[i] = self.segfunc(self.tree[2 * i], self.tree[2 * i + 1])import sys,random,bisectfrom collections import deque,defaultdictfrom heapq import heapify,heappop,heappushfrom itertools import permutationsfrom math import e, log,gcdinput = lambda :sys.stdin.readline()mi = lambda :map(int,input().split())li = lambda :list(mi())N,S = mi()P = li()for i in range(N):P[i] = P[i] * pow(S,mod-2,mod) % modinit = [[[0,P[i]*P[i] % mod],[1,P[i]]] for i in range(N)]def add(f,g):res = [0 for i in range(max(len(f),len(g)))]for i in range(len(f)):res[i] += f[i]for j in range(len(g)):res[j] += g[j]return resdef merge(x,y):return [add(convolve(x[0],y[1],N+1),convolve(x[1],y[0],N+1)),convolve(x[1],y[1],N+1)]seg = SegmentTree(init,merge,[[1,0],[1,0]])res = seg.tree[1][0]ans = 0for k in range(1,N+1):ans += g1[k+1] * res[k] % modans %= modprint(ans)