Pagini recente » Borderou de evaluare (job #1711739) | Cod sursa (job #1504033) | Cod sursa (job #2183198) | Cod sursa (job #602987) | Cod sursa (job #3358153)
#include <fstream>
#include <set>
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;
if(k==1)
{
out<<(m==0)?1:0;
return 0;
}
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]+dp[i-k];
if(brk.find(i)!=brk.end())
dp[i]=0;
}
out<<dp[n];
return 0;
}