QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#734302 | #5. 在线 O(1) 逆元 | zyzzyh | 10 | 510ms | 3708kb | C++20 | 2.6kb | 2024-11-11 08:42:55 | 2024-11-11 08:42:55 |
Judging History
answer
#include<bits/stdc++.h>
#include"inv.h"
using namespace std;
const int N = 1e6+100;
typedef long long ll;
ll a,b;
inline void mod(ll &x)
{
if(x>=1071856712387919872)x-=1071856712387919872;
if(x>=535928356193959936)x-=535928356193959936;
if(x>=267964178096979968)x-=267964178096979968;
if(x>=133982089048489984)x-=133982089048489984;
if(x>=66991044524244992)x-=66991044524244992;
if(x>=33495522262122496)x-=33495522262122496;
if(x>=16747761131061248)x-=16747761131061248;
if(x>=8373880565530624)x-=8373880565530624;
if(x>=4186940282765312)x-=4186940282765312;
if(x>=2093470141382656)x-=2093470141382656;
if(x>=1046735070691328)x-=1046735070691328;
if(x>=523367535345664)x-=523367535345664;
if(x>=261683767672832)x-=261683767672832;
if(x>=130841883836416)x-=130841883836416;
if(x>=65420941918208)x-=65420941918208;
if(x>=32710470959104)x-=32710470959104;
if(x>=16355235479552)x-=16355235479552;
if(x>=8177617739776)x-=8177617739776;
if(x>=4088808869888)x-=4088808869888;
if(x>=2044404434944)x-=2044404434944;
if(x>=1022202217472)x-=1022202217472;
if(x>=511101108736)x-=511101108736;
if(x>=255550554368)x-=255550554368;
if(x>=127775277184)x-=127775277184;
if(x>=63887638592)x-=63887638592;
if(x>=31943819296)x-=31943819296;
if(x>=15971909648)x-=15971909648;
if(x>=7985954824)x-=7985954824;
if(x>=3992977412)x-=3992977412;
if(x>=1996488706)x-=1996488706;
if(x>=998244353)x-=998244353;
return;
}
void init(int p)
{
;
}
int inv(int xx)
{
ll res=1,x=xx;
res=res*x,mod(res);
x=x*x,mod(x);
res=res*x,mod(res);
x=x*x,mod(x);
res=res*x,mod(res);
x=x*x,mod(x);
res=res*x,mod(res);
x=x*x,mod(x);
res=res*x,mod(res);
x=x*x,mod(x);
res=res*x,mod(res);
x=x*x,mod(x);
res=res*x,mod(res);
x=x*x,mod(x);
res=res*x,mod(res);
x=x*x,mod(x);
res=res*x,mod(res);
x=x*x,mod(x);
res=res*x,mod(res);
x=x*x,mod(x);
res=res*x,mod(res);
x=x*x,mod(x);
res=res*x,mod(res);
x=x*x,mod(x);
res=res*x,mod(res);
x=x*x,mod(x);
res=res*x,mod(res);
x=x*x,mod(x);
res=res*x,mod(res);
x=x*x,mod(x);
res=res*x,mod(res);
x=x*x,mod(x);
res=res*x,mod(res);
x=x*x,mod(x);
res=res*x,mod(res);
x=x*x,mod(x);
res=res*x,mod(res);
x=x*x,mod(x);
res=res*x,mod(res);
x=x*x,mod(x);
res=res*x,mod(res);
x=x*x,mod(x);
res=res*x,mod(res);
x=x*x,mod(x);
res=res*x,mod(res);
x=x*x,mod(x);
x=x*x,mod(x);
res=res*x,mod(res);
x=x*x,mod(x);
res=res*x,mod(res);
x=x*x,mod(x);
x=x*x,mod(x);
res=res*x,mod(res);
x=x*x,mod(x);
res=res*x,mod(res);
x=x*x,mod(x);
res=res*x,mod(res);
x=x*x,mod(x);
return res;
}
详细
Pretests
Final Tests
Test #1:
score: 10
Accepted
time: 510ms
memory: 3708kb
Test #2:
score: 0
Time Limit Exceeded
Test #3:
score: 0
Time Limit Exceeded
Test #4:
score: 0
Time Limit Exceeded
Test #5:
score: 0
Time Limit Exceeded