Pagini recente » Cod sursa (job #763616) | Cod sursa (job #2909347) | Cod sursa (job #364782) | Cod sursa (job #3281986) | Cod sursa (job #2575721)
#include <iostream>
#include <fstream>
#include <cmath>
using namespace std;
ifstream f("diamant.in");
ofstream g("diamant.out");
int N,M,X,sum,nr,v[405],cnt;
const int c=10000,Mx=44100;
int dp[405][44500];
int main()
{
f>>N>>M>>X;
for(int i=1; i<=N; i++)
for(int j=1; j<=M; j++)
{
sum+=(i*j);
v[++cnt]=i*j;
}
if(X<0)
X*=-1;
if(sum==abs(X))
g<<1;
else
{
if(sum<X || X<-sum)
g<<0;
else
{
dp[0][X]=1;
for(int i=1; i<=M*N; i++)
{
for(int j=0; j<=2*X; j++)
dp[i][j+X]=dp[i-1][j+X-v[i]]%c+dp[i-1][j+X+v[i]]%c+dp[i-1][j+X]%c;
}
g<<dp[N*M][X]%c;
}
}
return 0;
}