ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#196283 | #37. 染色 | 18681375979 | 100 | 3568ms | 313772kb | C++ | 631b | 2023-10-20 16:34:03 | 2023-10-20 16:34:06 |
answer
#include<algorithm>
#include<cstring>
#include<cstdio>
#include<iostream>
using namespace std;
typedef long long ll;
const int N=5000+15;
int n,m;
ll p;
ll f[N][N],sum[N][N];
int main()
{
cin>>n>>m>>p;
f[0][0]=1;
for (int i=1;i<=n;i++)
{
for (int j=1;j<=min(i,m-1);j++)
{
(f[i][j]+=f[i-1][j-1]*(m-(j-1))%p)%=p;
(f[i][j]+=sum[i-1][j])%=p;
}
for (int j=m-1;j>=1;j--)
{
sum[i][j]=(sum[i][j+1]+f[i][j])%p;
}
}
ll ans=0;
for (int i=1;i<m;i++) (ans+=f[n][i])%=p;
cout<<ans;
return 0;
}
Details
小提示:点击横条可展开更详细的信息
Test #1:
score: 5
Accepted
time: 0ms
memory: 1248kb
input:
5 2 6
output:
2
result:
ok 1 number(s): "2"
Test #2:
score: 5
Accepted
time: 0ms
memory: 1272kb
input:
8 8 562455908
output:
16736896
result:
ok 1 number(s): "16736896"
Test #3:
score: 5
Accepted
time: 0ms
memory: 16884kb
input:
1942 7 873185963
output:
41441893
result:
ok 1 number(s): "41441893"
Test #4:
score: 5
Accepted
time: 0ms
memory: 17696kb
input:
2030 10 187301366
output:
171496026
result:
ok 1 number(s): "171496026"
Test #5:
score: 5
Accepted
time: 0ms
memory: 38868kb
input:
4643 9 998244353
output:
583546139
result:
ok 1 number(s): "583546139"
Test #6:
score: 5
Accepted
time: 112ms
memory: 65808kb
input:
1447 3969 998244353
output:
669602806
result:
ok 1 number(s): "669602806"
Test #7:
score: 5
Accepted
time: 0ms
memory: 3588kb
input:
226 212 998244352
output:
503316480
result:
ok 1 number(s): "503316480"
Test #8:
score: 5
Accepted
time: 3ms
memory: 4640kb
input:
300 292 779230672
output:
95153840
result:
ok 1 number(s): "95153840"
Test #9:
score: 5
Accepted
time: 2ms
memory: 4112kb
input:
269 228 479932618
output:
244481530
result:
ok 1 number(s): "244481530"
Test #10:
score: 5
Accepted
time: 0ms
memory: 3264kb
input:
216 112 207794912
output:
145540448
result:
ok 1 number(s): "145540448"
Test #11:
score: 5
Accepted
time: 3ms
memory: 4452kb
input:
291 261 37264436
output:
28883269
result:
ok 1 number(s): "28883269"
Test #12:
score: 5
Accepted
time: 0ms
memory: 4124kb
input:
273 218 960539553
output:
718739009
result:
ok 1 number(s): "718739009"
Test #13:
score: 5
Accepted
time: 272ms
memory: 112400kb
input:
2991 2318 704783019
output:
517763339
result:
ok 1 number(s): "517763339"
Test #14:
score: 5
Accepted
time: 179ms
memory: 88420kb
input:
4413 790 693631006
output:
634441922
result:
ok 1 number(s): "634441922"
Test #15:
score: 5
Accepted
time: 752ms
memory: 296996kb
input:
4786 4581 2
output:
1
result:
ok 1 number(s): "1"
Test #16:
score: 5
Accepted
time: 836ms
memory: 306636kb
input:
4953 4424 876277826
output:
746769658
result:
ok 1 number(s): "746769658"
Test #17:
score: 5
Accepted
time: 15ms
memory: 43260kb
input:
4921 37 699201223
output:
206663263
result:
ok 1 number(s): "206663263"
Test #18:
score: 5
Accepted
time: 252ms
memory: 114640kb
input:
4991 994 533908193
output:
86765287
result:
ok 1 number(s): "86765287"
Test #19:
score: 5
Accepted
time: 882ms
memory: 313772kb
input:
5000 5000 640462742
output:
518214138
result:
ok 1 number(s): "518214138"
Test #20:
score: 5
Accepted
time: 260ms
memory: 114092kb
input:
4935 1005 961254358
output:
202283451
result:
ok 1 number(s): "202283451"
Extra Test:
score: 0
Extra Test Passed