Nomoca_xie @ 2024-05-14 13:21:35
rt 本地,在线ide都可以运行,o2开不开都RE
#include<bits/stdc++.h>
using namespace std;
long long fl[21][21][21];
long long w(long long a,long long b,long long c){
if(fl[a][b][c]) return fl[a][b][c];
long long ans;
if(a<=0||b<=0||c<=0) ans=1;
else if(a>20||b>20||c>20) ans=w(20,20,20);
else if(a<b&&b<c) ans=w(a,b,c-1)+w(a,b-1,c-1)-w(a,b-1,c);
else ans=w(a-1,b,c)+w(a-1,b-1,c)+w(a-1,b,c-1)-w(a-1,b-1,c-1);
fl[a][b][c]=ans;
return ans;
}
int main(){
long long a,b,c;
a=b=c=0;
while(a!=-1||b!=-1||c!=-1)
{
scanf("%lld%lld%lld",&a,&b,&c);
if(a!=-1||b!=-1||c!=-1) printf("w(%lld, %lld, %lld) = %lld\n",a,b,c,w(a,b,c));
}
return 0;
}
by Assiduity_by @ 2024-06-21 18:10:20
a=200 b=200 c=200时,爆了,你的数组就装不下了。 所以当a>20||b>20||c>20时,将a,b,c都复制成20,再开始运行。也就是if一下。