题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6581
题意:给出车子的位置,长度,最大速度,不能超车,求最后面车子的最快通过时间
题解:二分时间,从后往前可以推出每辆车的位置,推出第0辆车的位置,check第0辆车的位置即可。
代码:
#include <iostream>
#define inf 0x3f3f3f3f
#define Pair pair<int,int>
#define int long long
#define fir first
#define sec second
const double eps=1e7;
namespace fastIO{
#define BUF_SIZE 100000
#define OUT_SIZE 100000
//fread->read
bool IOerror=0;
//inline char nc(){char ch=getchar();if(ch==-1)IOerror=1;return ch;}
inline char nc(){
static char buf[BUF_SIZE],*p1=buf+BUF_SIZE,*pend=buf+BUF_SIZE;
if(p1==pend){
p1=buf;pend=buf+fread(buf,1,BUF_SIZE,stdin);
if(pend==p1){IOerror=1;return -1;}
}
return *p1++;
}
inline bool blank(char ch){return ch==' '||ch=='\n'||ch=='\r'||ch=='\t';}
template<class T> inline bool read(T &x){
bool sign=0;char ch=nc();x=0;
for(;blank(ch);ch=nc());
if(IOerror)return false;
if(ch=='-')sign=1,ch=nc();
for(;ch>='0'&&ch<='9';ch=nc())x=x*10+ch-'0';
if(sign)x=-x;
return true;
}
inline bool read(double &x){
bool sign=0;char ch=nc();x=0;
for(;blank(ch);ch=nc());
if(IOerror)return false;
if(ch=='-')sign=1,ch=nc();
for(;ch>='0'&&ch<='9';ch=nc())x=x*10+ch-'0';
if(ch=='.'){double tmp=1; ch=nc();for(;ch>='0'&&ch<='9';ch=nc())tmp/=10.0,x+=tmp*(ch-'0');}
if(sign)x=-x;return true;
}
inline bool read(char *s){
char ch=nc();
for(;blank(ch);ch=nc());
if(IOerror)return false;
for(;!blank(ch)&&!IOerror;ch=nc())*s++=ch;
*s=0;
return true;
}
inline bool read(char &c){
for(c=nc();blank(c);c=nc());
if(IOerror){c=-1;return false;}
return true;
}
template<class T,class... U>bool read(T& h,U&... t){return read(h)&&read(t...);}
#undef OUT_SIZE
#undef BUF_SIZE
};using namespace fastIO;using namespace std;
const int N=2e5+5;
const int mod=1e9+7;
int l[N],s[N],v[N];
double pos[N];
int n;
bool f(double t){
pos[n]=s[n]-t*v[n];
for(int i=n-1;i>=0;i--)pos[i]=max(s[i]-t*v[i],l[i+1]*1.0+pos[i+1]);
return pos[0]<0;
}
signed main(){
while(read(n)){
for(int i=0;i<=n;i++)read(l[i]);
for(int i=0;i<=n;i++)read(s[i]);
for(int i=0;i<=n;i++)read(v[i]);
double l=0,r=1e9;
for(int i=0;i<100;i++){
double mid=(l+r)/2.0;
if(f(mid))r=mid;
else l=mid;
}
printf("%.6lf\n",r);
}
return 0;
}