Pagini recente » Cod sursa (job #3205354) | Cod sursa (job #562707) | Cod sursa (job #2372270) | Cod sursa (job #2704238) | Cod sursa (job #2483955)
#include <bits/stdc++.h>
#define MOD 10000
#define add 50000
#define rest(a) (a-a/MOD*MOD);
typedef long long ll;
ll n, i, j, m, x, k, mx, c;
ll list[100001], rep[100001];
int main()
{
freopen("diamant.in", "r", stdin);
freopen("diamant.out", "w", stdout);
scanf("%lld%lld%lld", &n, &m, &x);
list[0+add]=1;
mx=m*n*(n+1)*(m+1)/4;
if(x>=mx || x<=-mx){
printf("0");
return 0;
}
for(i=1; i<=n; ++i){
for(j=1; j<=m; ++j){
if(c%2==0)
for(k=-mx+add; k<=mx+add; ++k){
rep[k]=list[k]+list[k-i*j]+list[k+i*j];
rep[k]=rest(rep[k]);
}
else
for(k=-mx+add; k<=mx+add; ++k) {
list[k]=rep[k]+rep[k-i*j]+rep[k+i*j];
list[k]=rest(list[k]);
}
++c;
}
}
if(c%2==0)printf("%lld", list[x+add]);
else printf("%lld", rep[x+add]);
fclose(stdin);
fclose(stdout);
return 0;
}