QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#719052 | #9612. 月亮的背面是粉红色的 | zhouhuanyi | 100 ✓ | 2315ms | 28948kb | C++17 | 3.6kb | 2024-11-06 22:14:34 | 2024-11-06 22:14:36 |
Judging History
answer
#include<iostream>
#include<cstdio>
#include<cmath>
#include<unordered_map>
#define N 1000000
#define mod 1000000007
using namespace std;
long long read()
{
char c=0;
long long sum=0;
while (c<'0'||c>'9') c=getchar();
while ('0'<=c&&c<='9') sum=sum*10+c-'0',c=getchar();
return sum;
}
void Adder(int &x,int d)
{
x=x+d>=mod?x+d-mod:x+d;
return;
}
void Adder2(int &x,int d)
{
x=x+d<0?x+d+mod:x+d;
return;
}
int MD(int x)
{
return x>=mod?x-mod:x;
}
int MD2(int x)
{
return x<0?x+mod:x;
}
long long n;
int sn,m,d,ans,ans2,sd[N+1],tong[N+1],length,miu[N+1],delta[N+1],smiu[N+1],sdelta[N+1];
bool nprime[N+1];
int get_sqrt(long long x)
{
int sx=sqrt(x);
while (1ll*(sx+1)*(sx+1)<=x) ++sx;
while (1ll*sx*sx>x) --sx;
return sx;
}
int get_cbrt(long long x)
{
int sx=pow(x,1.0/3);
while (1ll*(sx+1)*(sx+1)*(sx+1)<=x) ++sx;
while (1ll*sx*sx*sx>x) --sx;
return sx;
}
struct reads
{
long long x,y;
};
reads P,L,R,stk[N+1];
int top;
reads operator + (reads a,reads b)
{
return (reads){a.x+b.x,a.y+b.y};
}
bool check(long long x,reads d)
{
return x<1ll*d.x*d.y;
}
bool check2(long long x,long long y,reads d)
{
return (__int128)(x)*d.x<=(__int128)(y)*y*d.y;
}
int calc(long long x)
{
if (x<=N) return sd[x];
long long d=get_sqrt(x),d2=get_cbrt(x),ans=0;
top=0,P=(reads){x/d,d+1},stk[++top]=(reads){1,0},stk[++top]=(reads){1,1};
while (1)
{
L=stk[top--];
while (check(x,(reads){P.x+L.x,P.y-L.y})) ans+=(__int128)(P.x)*L.y+(((__int128)(L.y+1)*(L.x-1))>>1),P.x+=L.x,P.y-=L.y;
if(P.y<=d2) break;
R=stk[top];
while (!check(x,(reads){P.x+R.x,P.y-R.y})) L=R,R=stk[--top];
while (1)
{
reads mid=L+R;
if (check(x,(reads){P.x+mid.x,P.y-mid.y})) R=stk[++top]=mid;
else if(check2(x,P.x+mid.x,R)) break;
else L=mid;
}
}
for (int i=1;i<P.y;++i) ans+=x/i;
return (ans*2-d*d)%mod;
}
int calc2(long long x)
{
__int128 res=0;
int d=get_sqrt(x);
for (int i=1;i<=d;++i) res+=(((__int128)(x/i)*(x/i+1)*i)>>1);
return (2*res-((((__int128)(d)*d*(d+1)*(d+1)))>>2))%mod;
}
unordered_map<int,int>dp;
unordered_map<int,int>dp2;
int S2(int x)
{
return ((__int128)(x)*(x+1)*((x<<1)+1)/6)%mod;
}
int solve(int x)
{
if (x<=N) return smiu[x];
if (dp.find(x)!=dp.end()) return dp[x];
long long res=1;
for (int i=2,lst;i<=x;i=lst+1) lst=x/(x/i),res-=1ll*solve(x/i)*(lst-i+1);
res=MD2(res%mod),dp[x]=res;
return res;
}
int solve2(int x)
{
if (x<=N) return sdelta[x];
if (dp2.find(x)!=dp2.end()) return dp2[x];
__int128 res=1;
for (int i=2,lst;i<=x;i=lst+1) lst=x/(x/i),res-=1ll*solve2(x/i)*(S2(lst)-S2(i-1));
res=MD2(res%mod),dp2[x]=res;
return res;
}
int main()
{
n=read(),m=read(),sn=get_sqrt(n);
for (int i=1;i<=N;++i) miu[i]=delta[i]=1;
for (int i=2;i<=N;++i)
if (!nprime[i])
{
miu[i]=mod-1,delta[i]=MD2(-1ll*i*i%mod);
for (int j=(i<<1);j<=N;j+=i)
{
nprime[j]=1,miu[j]=MD2(-miu[j]),delta[j]=MD2(-1ll*delta[j]*i%mod*i%mod);
if ((j/i)%i==0) miu[j]=delta[j]=0;
}
}
for (int i=1;i<=N;++i) smiu[i]=MD(smiu[i-1]+miu[i]),sdelta[i]=MD(sdelta[i-1]+delta[i]);
for (int i=1;i<=N;++i)
for (int j=i;j<=N;j+=i)
sd[j]++;
for (int i=2;i<=N;++i) sd[i]+=sd[i-1];
for (long long i=1,d,lst;i<=sn;i=lst+1) d=n/(i*i),lst=get_sqrt(n/d),Adder(ans,1ll*MD2(solve(lst)-solve(i-1))*calc(d)%mod);
if (!m)
{
printf("%lld\n",1ll*ans*ans%mod);
return 0;
}
for (long long i=1,d,lst;i<=sn;i=lst+1) d=n/(i*i),lst=get_sqrt(n/d),Adder(ans2,1ll*MD2(solve2(lst)-solve2(i-1))*calc2(d)%mod);
printf("%lld %lld\n",1ll*ans*ans%mod,1ll*ans2*ans2%mod);
return 0;
}
详细
Subtask #1:
score: 3
Accepted
Test #1:
score: 3
Accepted
time: 50ms
memory: 26088kb
input:
1726 1
output:
84290761 74619067
result:
ok 2 number(s): "84290761 74619067"
Test #2:
score: 3
Accepted
time: 42ms
memory: 28148kb
input:
3608 1
output:
433014481 672891299
result:
ok 2 number(s): "433014481 672891299"
Test #3:
score: 3
Accepted
time: 45ms
memory: 26288kb
input:
2921 1
output:
271096225 547734266
result:
ok 2 number(s): "271096225 547734266"
Subtask #2:
score: 3
Accepted
Test #4:
score: 3
Accepted
time: 43ms
memory: 26420kb
input:
6116899 1
output:
219318963 301450440
result:
ok 2 number(s): "219318963 301450440"
Test #5:
score: 3
Accepted
time: 43ms
memory: 26416kb
input:
6260707 1
output:
148720176 263856753
result:
ok 2 number(s): "148720176 263856753"
Test #6:
score: 3
Accepted
time: 42ms
memory: 26404kb
input:
6763677 1
output:
944542490 136397156
result:
ok 2 number(s): "944542490 136397156"
Subtask #3:
score: 8
Accepted
Test #7:
score: 8
Accepted
time: 47ms
memory: 26372kb
input:
6469467712 0
output:
147393348
result:
ok 1 number(s): "147393348"
Test #8:
score: 8
Accepted
time: 40ms
memory: 26328kb
input:
8967004453 0
output:
229436583
result:
ok 1 number(s): "229436583"
Test #9:
score: 8
Accepted
time: 52ms
memory: 26372kb
input:
6636594384 0
output:
995965072
result:
ok 1 number(s): "995965072"
Subtask #4:
score: 8
Accepted
Test #10:
score: 8
Accepted
time: 51ms
memory: 26580kb
input:
8292948816 1
output:
566765721 287485757
result:
ok 2 number(s): "566765721 287485757"
Test #11:
score: 8
Accepted
time: 43ms
memory: 26360kb
input:
8592748771 1
output:
649470692 164561252
result:
ok 2 number(s): "649470692 164561252"
Test #12:
score: 8
Accepted
time: 43ms
memory: 26368kb
input:
9827380808 1
output:
291159931 188690805
result:
ok 2 number(s): "291159931 188690805"
Subtask #5:
score: 8
Accepted
Test #13:
score: 8
Accepted
time: 91ms
memory: 26460kb
input:
900472451132 1
output:
247050500 963765719
result:
ok 2 number(s): "247050500 963765719"
Test #14:
score: 8
Accepted
time: 99ms
memory: 26428kb
input:
850862494659 1
output:
200210720 915108650
result:
ok 2 number(s): "200210720 915108650"
Test #15:
score: 8
Accepted
time: 97ms
memory: 26596kb
input:
851346512859 1
output:
895785763 504512885
result:
ok 2 number(s): "895785763 504512885"
Subtask #6:
score: 10
Accepted
Test #16:
score: 10
Accepted
time: 231ms
memory: 26368kb
input:
9864907300784 1
output:
359943536 720268421
result:
ok 2 number(s): "359943536 720268421"
Test #17:
score: 10
Accepted
time: 212ms
memory: 26388kb
input:
8181674676063 1
output:
839993102 994056029
result:
ok 2 number(s): "839993102 994056029"
Test #18:
score: 10
Accepted
time: 225ms
memory: 26308kb
input:
9893510217522 1
output:
157499971 930653488
result:
ok 2 number(s): "157499971 930653488"
Subtask #7:
score: 13
Accepted
Test #19:
score: 13
Accepted
time: 247ms
memory: 28456kb
input:
96735749745529 0
output:
223354886
result:
ok 1 number(s): "223354886"
Test #20:
score: 13
Accepted
time: 241ms
memory: 26400kb
input:
95243570720799 0
output:
555372474
result:
ok 1 number(s): "555372474"
Test #21:
score: 13
Accepted
time: 248ms
memory: 26552kb
input:
97668723090105 0
output:
84562124
result:
ok 1 number(s): "84562124"
Subtask #8:
score: 14
Accepted
Test #22:
score: 14
Accepted
time: 642ms
memory: 26560kb
input:
94060593399194 1
output:
52991150 887133157
result:
ok 2 number(s): "52991150 887133157"
Test #23:
score: 14
Accepted
time: 660ms
memory: 26540kb
input:
98527940728119 1
output:
281611635 910356955
result:
ok 2 number(s): "281611635 910356955"
Test #24:
score: 14
Accepted
time: 637ms
memory: 26444kb
input:
90501814019947 1
output:
666385143 229785369
result:
ok 2 number(s): "666385143 229785369"
Subtask #9:
score: 16
Accepted
Test #25:
score: 16
Accepted
time: 2298ms
memory: 26824kb
input:
9772457586483846 0
output:
631039552
result:
ok 1 number(s): "631039552"
Test #26:
score: 16
Accepted
time: 2313ms
memory: 26892kb
input:
9889806164705403 0
output:
169322134
result:
ok 1 number(s): "169322134"
Test #27:
score: 16
Accepted
time: 2243ms
memory: 26984kb
input:
9422498258316766 0
output:
413943782
result:
ok 1 number(s): "413943782"
Test #28:
score: 16
Accepted
time: 2315ms
memory: 26908kb
input:
9845978636381962 0
output:
857401052
result:
ok 1 number(s): "857401052"
Test #29:
score: 16
Accepted
time: 2291ms
memory: 26832kb
input:
9761171951453691 0
output:
205712009
result:
ok 1 number(s): "205712009"
Test #30:
score: 16
Accepted
time: 2225ms
memory: 28948kb
input:
9224667465673566 0
output:
143979878
result:
ok 1 number(s): "143979878"
Subtask #10:
score: 17
Accepted
Test #31:
score: 17
Accepted
time: 2095ms
memory: 26696kb
input:
949243849085176 1
output:
508465534 771553755
result:
ok 2 number(s): "508465534 771553755"
Test #32:
score: 17
Accepted
time: 2061ms
memory: 26492kb
input:
924225524519163 1
output:
867410272 870831653
result:
ok 2 number(s): "867410272 870831653"
Test #33:
score: 17
Accepted
time: 2112ms
memory: 26492kb
input:
978079151303393 1
output:
235076358 675828942
result:
ok 2 number(s): "235076358 675828942"
Test #34:
score: 17
Accepted
time: 2057ms
memory: 28548kb
input:
929804617107620 1
output:
790604296 73162158
result:
ok 2 number(s): "790604296 73162158"
Test #35:
score: 17
Accepted
time: 2140ms
memory: 26564kb
input:
989806727450552 1
output:
378550840 783149232
result:
ok 2 number(s): "378550840 783149232"