QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#252450 | #7710. Rikka with Equation | SolitaryDream# | AC ✓ | 282ms | 321220kb | C++17 | 1.6kb | 2023-11-15 19:42:55 | 2023-11-15 19:42:55 |
Judging History
answer
#include<bits/stdc++.h>
using namespace std;
#define int long long
const int N=1e7+1e3+7,P=998244353;
int T,n;
int ans[N],vis[N],p[N],ptot,cnt[N],fr[N];
int f(int p,int k)
{
if(p==2)
{
if(k==1)
return 3;
if(k==2)
return 5;
if(k==3)
return 11;
int ret=29,dlt=25;
for(int t=4;t<k;t++)
{
ret=(ret*4-dlt+P)%P;
if(t%2==1)
dlt=(dlt+10)%P;
else
dlt=(dlt*4-53+P)%P;
}
// cerr<<dlt<<" ";
return ret;
}
else
{
int ret=1;
for(int t=1;t<=k;t++)
ret=(ret*p%P-(t%2==0?p-1:(p-1)/2)+P)%P;
return ret*ret%P;
}
}
void pre(int n)
{
ans[1]=1;
for(int i=2;i<=n;i++)
{
if(!vis[i])
p[++ptot]=i,ans[i]=f(i,1),cnt[i]=1,fr[i]=1;
for(int j=1;j<=ptot&&i*p[j]<=n;j++)
{
vis[i*p[j]]=1;
ans[i*p[j]]=ans[i]*ans[p[j]]%P;
if(i%p[j])
cnt[i*p[j]]=1,fr[i*p[j]]=i;
if(i%p[j]==0)
{
cnt[i*p[j]]=cnt[i]+1;
fr[i*p[j]]=fr[i];
ans[i*p[j]]=f(p[j],cnt[i*p[j]])*ans[fr[i*p[j]]]%P;
break;
}
}
}
// for(int i=1;i<=50;i++)
// cout<<ans[i]<<"\n";
for(int i=1;i<=n;i++)
ans[i]=(ans[i]+ans[i-1])%P;
}
signed main()
{
ios::sync_with_stdio(false);
cin.tie(0);
pre(1e7);
cin>>T;
while(T--)
{
cin>>n;
cout<<ans[n]<<"\n";
}
}
详细
Test #1:
score: 100
Accepted
time: 243ms
memory: 321220kb
input:
5 3 5 10 100 1000
output:
8 22 104 45933 32791150
result:
ok 5 number(s): "8 22 104 45933 32791150"
Test #2:
score: 0
Accepted
time: 282ms
memory: 321116kb
input:
100000 8045782 8876486 8163011 8344042 9378740 2908104 7853239 1557591 6565197 5962616 7951650 7994086 4609270 5375583 3214533 3208595 7727951 4566166 6848279 9075146 3592143 4991697 3179065 7683833 4880753 6492999 8016415 6388967 1319335 269048 1712061 5888121 3847377 7435670 1768073 655758 6372575...
output:
566372506 613340079 457470593 909412476 204288085 145326690 470913242 580308507 451513374 742372505 578473430 164558269 901594473 47845389 44481127 90637625 933713038 936835953 115876485 201678620 924867979 120570904 376719500 699611349 285842222 772019635 996465492 526862153 638097420 586450685 867...
result:
ok 100000 numbers