Pagini recente » Cod sursa (job #2374448) | Cod sursa (job #248486) | Cod sursa (job #558206) | Cod sursa (job #3211665) | Cod sursa (job #770472)
Cod sursa(job #770472)
#include<fstream>
#include<deque>
using namespace std;
deque < pair <int, int> > A;
int n, k, x, y, res = -30001;
void solve()
{
ifstream f("secventa.in");
int i, val;
f >> n >> k;
for(i = 1; i < k; i++)
{
f >> val;
while(!A.empty() && val <= A.back().second)
A.pop_back();
A.push_back(make_pair(i, val));
if(i - k == A.front().first)
A.pop_front();
}
for( ; i <= n; i++)
{
f >> val;
while(!A.empty() && val <= A.back().second)
A.pop_back();
A.push_back(make_pair(i, val));
if(i - k == A.front().first)
A.pop_front();
if(A.front().second > res)
res = A.front().second, y = i;
}
f.close();
x = y - k + 1;
}
void write()
{
ofstream g("secventa.out");
g << x << " " << y << " " << res << '\n';
g.close();
}
int main()
{
solve();
write();
return 0;
}