QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#833577 | #4007. 树 | Kevin5307 | 100 ✓ | 344ms | 501560kb | C++23 | 1.4kb | 2024-12-26 21:30:54 | 2024-12-26 21:30:55 |
Judging History
answer
//Author: Kevin
#include<bits/stdc++.h>
//#pragma GCC optimize("O2")
using namespace std;
#define ll long long
#define ull unsigned ll
#define pb emplace_back
#define mp make_pair
#define ALL(x) (x).begin(),(x).end()
#define rALL(x) (x).rbegin(),(x).rend()
#define srt(x) sort(ALL(x))
#define rev(x) reverse(ALL(x))
#define rsrt(x) sort(rALL(x))
#define sz(x) (int)(x.size())
#define inf 0x3f3f3f3f
#define pii pair<int,int>
#define lb(v,x) (int)(lower_bound(ALL(v),x)-v.begin())
#define ub(v,x) (int)(upper_bound(ALL(v),x)-v.begin())
#define uni(v) v.resize(unique(ALL(v))-v.begin())
#define longer __int128_t
void die(string S){puts(S.c_str());exit(0);}
int n,m;
int f[505][505][505];
void calc(int n)
{
for(int i=0;i<=n;i++)
for(int a=0;a<=n;a++)
for(int b=0;b<=n;b++)
f[i][a][b]=0;
for(int i=0;i<n;i++)
f[1][0][i]=(m-i%m)%m;
for(int i=1;i<n-1;i++)
for(int a=0;a<i;a++)
for(int b=1;b<=n-i;b++)
{
if(b)
f[i+1][a+1][b]=(f[i+1][a+1][b]+1ll*f[i][a][b]*(i-a)*b*2)%m;
if(b)
f[i+1][a][b]=(f[i+1][a][b]-1ll*f[i][a][b]*(i-a)*b%m+m)%m;
f[i+1][a+1][b-1]=(f[i+1][a+1][b-1]-1ll*f[i][a][b]*(i-a)*(b-1)%m+m)%m;
}
for(int i=2;i<=n;i++)
{
int ans=0;
for(int j=0;j<i;j++)
ans=(ans+1ll*f[i-1][j][1]*(i-1-j))%m;
if(i%2==0) ans=(m-ans)%m;
cout<<ans<<'\n';
}
}
int main()
{
ios_base::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);
cin>>n>>m;
calc(n);
return 0;
}
詳細信息
Pretests
Final Tests
Test #1:
score: 10
Accepted
time: 2ms
memory: 13924kb
input:
10 577151064
output:
1 2 12 120 1928 44368 1394944 57288704 94480200
result:
ok 9 numbers
Test #2:
score: 10
Accepted
time: 0ms
memory: 22220kb
input:
20 993244853
output:
1 2 12 120 1928 44368 1394944 57288704 500961 765914688 721727386 828519746 578809878 456780398 566346177 528608756 112517275 556697045 568491469
result:
ok 19 numbers
Test #3:
score: 10
Accepted
time: 2ms
memory: 50876kb
input:
48 693389412
output:
1 2 12 120 1928 44368 1394944 57288704 206677872 93448752 311229980 378398080 125171140 600238484 463296372 561311928 329571716 372970120 613153144 269319584 39317988 650402652 168384404 534851656 34323712 215031272 571825440 276426924 452666204 65470204 266586376 160926452 211220340 374251752 67686...
result:
ok 47 numbers
Test #4:
score: 10
Accepted
time: 5ms
memory: 52996kb
input:
50 1000000021
output:
1 2 12 120 1928 44368 1394944 57288704 980235478 468922453 461761187 992820728 222191705 300367066 987453727 296887978 372555015 955448207 763668619 979367361 619326086 386572917 557116733 365169253 648460492 571297313 590441681 957006239 722930829 488988561 87845027 317417171 474978324 228338990 66...
result:
ok 49 numbers
Test #5:
score: 10
Accepted
time: 7ms
memory: 100136kb
input:
97 192608170
output:
1 2 12 120 1928 44368 1394944 57288704 91112970 16405484 80100176 70225008 48127872 176500510 39558398 22009052 21398644 141840316 189415170 192276316 116361256 72578142 52819502 188156950 188410248 176509638 32522564 83818754 28928230 65470204 73978206 122404818 134177072 66078680 21994318 88253492...
result:
ok 96 numbers
Test #6:
score: 10
Accepted
time: 8ms
memory: 104272kb
input:
100 949494599
output:
1 2 12 120 1928 44368 1394944 57288704 131751723 620512065 437266937 358823802 539191611 176844929 543845036 668141281 801642858 243456188 475342903 130532838 725579466 483897130 428695490 554394226 640052996 822143891 597926520 115217926 933551207 829213453 163959314 857759387 609179400 110139502 2...
result:
ok 99 numbers
Test #7:
score: 10
Accepted
time: 320ms
memory: 496364kb
input:
497 1000000008
output:
1 2 12 120 1928 44368 1394944 57288704 980235504 468924936 461954744 10738360 169104280 683889128 729152376 260582112 579791480 979908304 54091792 859511360 218597448 706142496 963545672 872576584 795238216 742370576 97990344 903219288 323919296 630916264 620417560 260644760 296622888 919475496 1351...
result:
ok 496 numbers
Test #8:
score: 10
Accepted
time: 344ms
memory: 501376kb
input:
500 100000007
output:
1 2 12 120 1928 44368 1394944 57288704 80235317 68913066 61031598 25284945 83829366 93302789 23195091 38492081 50524333 45168633 38292434 94285811 38365623 95982662 36801914 61735054 86235593 37972035 84765574 17006323 9043467 77114223 34713566 69229620 79941112 8779017 72345539 90479258 69839002 49...
result:
ok 499 numbers
Test #9:
score: 10
Accepted
time: 323ms
memory: 501516kb
input:
500 996996996
output:
1 2 12 120 1928 44368 1394944 57288704 986241528 45503232 308935592 470590336 414864760 435663620 961356588 861801516 878901872 769566388 645880240 288459596 396098292 38002044 7683212 214317124 691055404 806441252 62125056 689603568 150044048 690550336 767023528 962388620 234709476 688741452 634303...
result:
ok 499 numbers
Test #10:
score: 10
Accepted
time: 323ms
memory: 501560kb
input:
500 1000000009
output:
1 2 12 120 1928 44368 1394944 57288704 980235502 468924745 461939855 9360079 19341771 808233360 364373546 411824196 637521641 722309870 778158561 500366017 204013945 366241252 504956853 971244083 263757822 671356722 954932924 63228980 314686787 611190004 716522667 145587103 747614824 444047280 94915...
result:
ok 499 numbers
Extra Test:
score: 0
Extra Test Passed