Pagini recente » Cod sursa (job #3334016) | Cod sursa (job #3318149) | Cod sursa (job #3330256) | Cod sursa (job #3314526) | Cod sursa (job #3352773)
#include <bits/stdc++.h>
using namespace std;
ifstream fin("secventa.in");
ofstream fout("secventa.out");
int v[500005];
deque <int> q;
int main()
{
int n, k;
fin >> n >> k;
for (int i = 1; i <= n; i++)
{
fin >> v[i];
}
int pmax = 0;
int lmax = 1;
int rmax = k;
for (int i = 1; i <= n; i++)
{
if (!q.empty() && q.front() <= i - k) { q.pop_front(); }
while (!q.empty() && v[q.back()] >= v[i]) { q.pop_back(); }
q.push_back(i);
if (i >= k)
if (v[q.front()] > v[pmax])
{
lmax = i - k + 1;
rmax = i;
pmax = q.front();
}
}
fout << lmax << " " << rmax << " " << v[pmax];
return 0;
}