Pagini recente » Cod sursa (job #1123868) | Cod sursa (job #1730554) | Cod sursa (job #1873876) | Cod sursa (job #1220879) | Cod sursa (job #465540)
Cod sursa(job #465540)
#include <fstream>
using namespace std;
int v[1<<19],dq[1<<19],st=1,dr=0;
ifstream in("secventa.in");
ofstream out("secventa.out");
inline void s(int x)
{
if (dq[st]==x)
st++;
}
void d(int x)
{
while (v[dq[dr]]>=v[x] && dr)
dr--;
dq[++dr]=x;
}
int main()
{
int n,k,i,x=0,y=0,maxim=-(1<<15);
in>>n>>k;
for (i=1;i<k;i++)
{
in>>v[i];
d(i);
}
for (;i<=n;i++)
{
in>>v[i];
s(i-k);
d(i);
if (v[dq[st]]>maxim)
{
maxim=v[dq[st]];
x=i-k+1;
y=i;
}
}
out<<x<<" "<<y<<" "<<maxim<<"\n";
return 0;
}