Cod sursa(job #1274977)

Utilizator lokixdSebastian lokixd Data 24 noiembrie 2014 17:06:12
Problema Secventa 3 Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 1.88 kb
#include <iostream>
#include <fstream>
#include <climits>
#include <deque>
#include <iomanip>
using namespace std;
ifstream fin("secv3.in");
ofstream fout("secv3.out");
#define MAX 30005
#define eps 0.01
typedef double f;
f a[MAX], s[MAX], c[MAX], t[MAX];
int n, l, u;
 
deque <int> Q;
 
f rez(f x)
{
    f maxim=-3000000;
    int i;
 
    for(i=1;i<=n;i++)
    {
        a[i]=c[i]-1.0*t[i]*x;
 
    }
  //  cout << "\n";
    for(i=1;i<=n;i++)
    {
        s[i]=a[i]+s[i-1];
        if(i>=l)
        {
            while(Q.size() && s[i-l]<s[Q.back()])
                Q.pop_back();
            Q.push_back(i-l);
            maxim=max(maxim, s[i]-s[Q.front()]);
            if(Q.front()==i-u)
                Q.pop_front();
        }
    }
    while(Q.size())
        Q.pop_back();
    return maxim;
}
 
int main()
{
    int i, j;
    f st, dr, mij, k;
    fin>>n>>l>>u;
    for(i=1;i<=n;i++)
    {
        fin>>c[i];
    }
    for(i=1;i<=n;i++)
    {
        fin>>t[i];
    }
 
    st=0;
    dr=30000000;
    while(dr-st>eps)
    {
 
        mij=1.0*(st+dr)/2;
        k=rez(mij);
 
        if(k==0)
        {
            cout << mij << "\n";
            return 0;
        }
        if(k>0)
            st=mij;
        else
            dr=mij;
    }
    fout << fixed << setprecision(2) << mij << "\n";
 
}

int main()
{
    int i, j;
    f st, dr, mij, k;
    fin>>n>>l>>u;
    for(i=1;i<=n;i++)
    {
        fin>>c[i];
    }
    for(i=1;i<=n;i++)
    {
        fin>>t[i];
    }
 
    st=0;
    dr=30000000;
    while(dr-st>eps)
    {
 
        mij=1.0*(st+dr)/2;
        k=rez(mij);
 
        if(k==0)
        {
            cout << mij << "\n";
            return 0;
        }
        if(k>0)
            st=mij;
        else
            dr=mij;
    }
    fout << fixed << setprecision(2) << mij << "\n";