Cod sursa(job #1484030)
| Utilizator | Data | 10 septembrie 2015 13:06:32 | |
|---|---|---|---|
| Problema | Zombie | Scor | 100 |
| Compilator | cpp | Status | done |
| Runda | Arhiva de probleme | Marime | 0.59 kb |
#include <cstdio>
#include <cstring>
#include <algorithm>
#define maxN 1000002
using namespace std;
int v[maxN], i, j, d, n, k, pos, dp[maxN];
void read()
{
freopen("zombie.in", "r", stdin);
scanf("%d %d %d", &d, &n, &k);
pos = 1;
for (i = 1; i <= n; ++ i)
{
scanf("%d", &v[i]);
while (pos < i && v[i] - v[pos] >= d)
++ pos;
dp[i] = min(dp[i - 1] + 1, dp[pos - 1] + k);
}
}
void write()
{
freopen("zombie.out", "w", stdout);
printf("%d\n", dp[n]);
}
int main()
{
read();
write();
return 0;
}
