Pagini recente » Cod sursa (job #2381812) | Cod sursa (job #1560538) | Cod sursa (job #2167449) | Cod sursa (job #1177707) | Cod sursa (job #2967339)
#include<iostream>
#include<fstream>
using namespace std;
ifstream f("diamant.in");
ofstream g("diamant.out");
int dp[2][88444],n,m;
long long x;
void citire()
{
f>>n>>m>>x;
}
void solve()
{
int summax = 0,sum = 0;
int ma,mi;
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
summax = summax + i * j;
int casute = 0;
dp[0][44100] = 1;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
sum = i * j;
summax = summax - sum;
ma = max(-44100 * 1LL + summax,x-summax);
mi = min(44100 * 1LL - summax, x + summax);
casute = casute ^ 1;
for(int k = ma; k<= mi;k++)
{
dp[casute][k + 44100] = dp[casute ^ 1][k + 44100];
dp[casute][k + 44100] += dp[casute^1][k - sum + 44100];
dp[casute][k + 44100] += dp[casute^1][k + sum + 44100];
dp[casute][k + 44100] = dp[casute][k + 44100] % 10000;
}
}
}
g<<dp[casute][44100 + x];
}
int main()
{
ios::sync_with_stdio(false);
cin.tie(NULL);
cout.tie(NULL);
citire();
solve();
}