Pagini recente » Diferente pentru problema/monede3 intre reviziile 5 si 4 | Monitorul de evaluare | Diferente pentru problema/nn intre reviziile 1 si 2 | Cod sursa (job #946697) | Cod sursa (job #2728261)
#include <iostream>
#include <fstream>
using namespace std;
int A[5000001], mydeque[5000001];
int main() {
ifstream in("deque.in");
ofstream out("deque.out");
int N, K, x, suma=0, inc=1, sf=0;
in>>N>>K;
for(int i=1; i<N+1; i++)
{
in>>x;
A[i]=x;
}
for(int i=1; i<N+1; i++)
{
while(inc<=sf && A[i]<=A[mydeque[sf]])
sf--;
mydeque[++sf]=i;
if(mydeque[inc]==i-K)
inc++;
if(i>=K)
suma+=A[mydeque[inc]];
}
out<<suma;
in.close();
out.close();
return 0;
}