Cod sursa(job #1024310)

Utilizator danutbodbodnariuc danut danutbod Data 8 noiembrie 2013 15:55:54
Problema Secventa Scor 80
Compilator cpp Status done
Runda Arhiva de probleme Marime 2.36 kb
//var II 100p cu parsare
//#include <fstream>
//#define NMax 1000003
//using namespace std;
//ifstream f("secventa.in");
//ofstream g("secventa.out");
//int a[NMax], deque[NMax],i,j,k,x,n,p,u,pi,pf,semn,maxi=-300000;
//string s;
//int main()
//{
//    f>>n>>k;f.get();
//    getline(f,s);s=s+" ";
//    x=0;semn=1;
//    for(i=0; i<s.length(); i++)
//      if(s[i]=='-')semn=-1;
//        else if(s[i]>='0'&&s[i]<='9')x=x*10+s[i]-'0';
//              else {a[++j]=semn*x;x=0;semn=1;}
//    p=1;u=0;
//    for(i=1; i<=n; i++)
//    {
//        while(p<=u && a[i]<a[deque[u]]) u--;
//        deque[++u]=i;
//        if(deque[p]==i-k) p++;
//        if(i>=k) if(maxi<a[deque[p]]){pi=i-k+1;pf=i;maxi=a[deque[p]];}
//    }
//    g<<pi<<" "<<pf<<" "<<maxi<<'\n';
//    return 0;
//}
//var I 80p fara parsare
#include <fstream>
#define NMax 1000003
using namespace std;
ifstream f("secventa.in");
ofstream g("secventa.out");
int a[NMax], deque[NMax],i,k,n,p,u,pi,pf,maxi=-300000;
int main()
{
    f>>n>>k;
    for(i=1; i<=n; i++) f>>a[i];
    p=1;u=0;
    for(i=1; i<=n; i++)
    {
        while(p<=u && a[i]<a[deque[u]]) u--;//<=  ??????
        deque[++u]=i;
        if(deque[p]==i-k) p++;
        if(i>=k)      if(maxi<a[deque[p]]){pi=i-k+1;pf=i;maxi=a[deque[p]];}
    }
    g<<pi<<" "<<pf<<" "<<maxi<<'\n';
    return 0;
}
//#include <fstream>
//#include <deque>
//#include <vector>
//using namespace std;
//deque <int> d;
//int i,n,k,b,a[500001],l;
//
//long long s;
//ifstream f("secventa.in");
//ofstream g("secventa.out");
//int main()
//{
//    f>>n>>k;
//    for (i=1;i<=n;i++)
//    {
//        f>>a[i];
//        while (!d.empty() && a[d.back()]>a[i]) d.pop_back();
//        d.push_back(i);
//        if (i-k==d.front()) d.pop_front();
//        if (i>=k && a[d.front()]>s)
//        {
//         l=i;
//         s=a[d.front()];
//        }
//    }
//    g<<l-k+1<<' '<<l<<' '<<s;
//    return 0;
//}
//#include <iostream>
//
//using namespace std;
//int i,n,s,x,r1,r2,r3,b,gr,c,f;
//int main()
//{
//    cin>>n;
//    for(i=1;i<=n;i++){
//     cout<<"dati numar";
//     cin>>x;
//     gr=x/1000;
//     if(gr==1)r1++;
//     if(gr==2)r2++;
//     if(gr==3)r3++;
//     b=b+x/100%10;
//     f=f+x/10%10;
//     c=c+x%10;
//    }
//    cout<<r1<<" "<<r2<<" "<<r3<<" "<<b<<" "<<f<<" "<<c;
//    return 0;
//}