Pagini recente » Cod sursa (job #676981) | Cod sursa (job #1540906) | Cod sursa (job #1807468) | Cod sursa (job #2223674) | Cod sursa (job #3358156)
#include <fstream>
#include <set>
#include <cassert>
using namespace std;
ifstream in("pod.in");
ofstream out("pod.out");
const int MMAX=1e3+5, NMAX=1e6+5, MOD=9901;
int n, m, k, dp[NMAX];
set<int> brk;
int main()
{
in>>n>>m>>k;
for(int i=1;i<=m;i++)
{
int x; in>>x;
brk.insert(x);
}
dp[0]=1;
for(int i=1;i<=n;i++)
{
dp[i]=dp[i-1];
if(i>=k)
dp[i]=(dp[i]+dp[i-k])%MOD;
if(brk.find(i)!=brk.end())
dp[i]=0;
}
out<<dp[n];
return 0;
}