Pagini recente » Cod sursa (job #3147155) | Cod sursa (job #401631) | Cod sursa (job #3149582) | Profil EugenStoica | Cod sursa (job #1275028)
#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";
}