Pagini recente » Cod sursa (job #2527797) | Cod sursa (job #2210756) | Cod sursa (job #2599312) | Cod sursa (job #1579182) | Cod sursa (job #2071987)
//#include <iostream>
#include <fstream>
#include <cstring>
using namespace std;
const int N=500001;
char s[N*8];
int st=0;
int dr=-1;
int v[N];
int d[N];
int main()
{
ifstream in("secventa.in");
ofstream out("secventa.out");
int n,k,rez=-300000,a=-30000,b=0;
in>>n>>k>>ws;
in.getline(s, 7*N+1);
int val=0, semn=1;
n=0;
int l=strlen(s);
for (int i=0; i<l; i++)
{
if(isdigit(s[i]))
{
val=val*10+(s[i]-'0');
}
else if(s[i]==' ')
{
v[++n]=val*semn;
val=0;
semn=1;
}
else
{
semn=-semn;
}
}
v[++n]=val*semn;
for (int i = 1; i<=n; i++)
{
while (st <= dr && v[i] <= v[d[dr]])
{
dr--;
}
d[++dr] = i;
if (st <= dr && d[st] == i - k)
{
st++;
}
//out << i - k + 1 << " " << i << " -> " << v[d[st]] << "\n";
if (i >= k && v[d[st]] > rez)
{
rez = v[d[st]];
a = i - k + 1;
b = i;
}
}
out<<rez<<" "<<a<<" "<<b;
return 0;
}