QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#480140 | #5. 在线 O(1) 逆元 | Williamxzh# | 80 | 5998ms | 121096kb | C++20 | 864b | 2024-07-16 08:43:13 | 2024-11-05 22:01:02 |
Judging History
answer
#include <bits/stdc++.h>
#include "inv.h"
#define il inline
#define B __int128
using namespace std;
typedef long long ll;
const int mod=998244353;
il ll qp(ll a,ll b){
ll ans=1ll;
while(b){
if(b&1) ans=(ans*a)%mod;
a=(a*a)%mod,b>>=1;
}return ans;
}
const ll N=1e7+5;
int n,fac[N],iv[N],a[N];
void init(int MOD){
n=N-5,fac[0]=1ll;for(int i=1;i<=n;++i) fac[i]=(1ll*fac[i-1]*i)%mod;
iv[n]=qp(fac[n],mod-2ll);for(int i=n-1;i>=0;--i) iv[i]=(iv[i+1]*(i+1ll))%mod;
for(int i=1;i<=n;++i) a[i]=(1ll*fac[i-1]*iv[i])%mod;
}
int inv(int x){
if(x<=n) return a[x];
int y=mod/x;
return 1ll*(mod-y)*inv(mod-x*y)%mod;
}
/*int main(){
init(mod);
mt19937 rnd(time(0));
for(int i=1;i<=100;++i){
int x=rnd()%(mod-1)+1;
//if(inv(x)!=qp(x,mod-2ll)) printf("%d %d %d\n",x,inv(x),qp(x,mod-2ll));
//else puts("*");
}
return 0;
} */
详细
Pretests
Final Tests
Test #1:
score: 10
Accepted
time: 120ms
memory: 120900kb
Test #2:
score: 20
Accepted
time: 812ms
memory: 120896kb
Test #3:
score: 30
Accepted
time: 3845ms
memory: 121080kb
Test #4:
score: 20
Accepted
time: 5998ms
memory: 121096kb
Test #5:
score: 0
Time Limit Exceeded