Cod sursa(job #3226830)
Utilizator | Data | 22 aprilie 2024 21:21:49 | |
---|---|---|---|
Problema | Secventa | Scor | 10 |
Compilator | cpp-64 | Status | done |
Runda | Arhiva de probleme | Marime | 0.64 kb |
#include <bits/stdc++.h>
using namespace std;
ifstream fin ("secventa.in");
ofstream fout ("secventa.out");
deque <pair<int,int>> d;
int main()
{
int n,x,Max = -999999999,k,st = 0;
fin >> n >> k;
for (int i=1;i<=n;++i){
fin >> x;
while (!d.empty() and i-d.front().second>=k) d.pop_front();
while (!d.empty() and d.back().first>=x) d.pop_back();
d.push_back({x,i});
if (i>=k){
if (Max<=d.front().first){
Max = d.front().first;
st = i;
}
}
}
fout << st-k+1 << ' ' << st << ' ' << Max;
return 0;
}