如果你是这么写的:
if(f[a][b][c]!=-1) return f[a][b][c];
if(a<=0 || b<=0 || c<=0) return 1;
if(a>20 || b>20 || c>20) return f[20][20][20]=dfs(20,20,20);
if(a<b && b<c) return f[a][b][c]=dfs(a,b,c-1)+dfs(a,b-1,c-1)-dfs(a,b-1,c);
return f[a][b][c]=dfs(a-1,b,c)+dfs(a-1,b-1,c)+dfs(a-1,b,c-1)-dfs(a-1,b-1,c-1);
若 a,b,c 太大,会数组越界,因此请把 if(f[a][b][c]!=-1) return f[a][b][c]; 写在后面,就像这样:
if(a<=0 || b<=0 || c<=0) return 1;
if(a>20 || b>20 || c>20) return f[20][20][20]=dfs(20,20,20);
if(f[a][b][c]!=-1) return f[a][b][c];
if(a<b && b<c) return f[a][b][c]=dfs(a,b,c-1)+dfs(a,b-1,c-1)-dfs(a,b-1,c);
return f[a][b][c]=dfs(a-1,b,c)+dfs(a-1,b-1,c)+dfs(a-1,b,c-1)-dfs(a-1,b-1,c-1);