C. Discrete Acceleration
Description
There is a road with length l meters. The start of the road has coordinate 0, the end of the road has coordinate l.
There are two cars, the first standing at the start of the road and the second standing at the end of the road. They will start driving simultaneously. The first car will drive from the start to the end and the second car will drive from the end to the start.
Initially, they will drive with a speed of 1 meter per second. There are n flags at different coordinates a1,a2,…,an. Each time when any of two cars drives through a flag, the speed of that car increases by 1 meter per second.
Find how long will it take for cars to meet (to reach the same coordinate).
Input
The first line contains one integer t (1≤t≤104): the number of test cases.
The first line of each test case contains two integers n, l ( 1 ≤ n ≤ 1 0 5 , 1 ≤ l ≤ 1 0 9 1≤n≤10^5, 1≤l≤10^9 1≤n≤105,1≤l≤109): the number of flags and the length of the road.
The second line contains n integers a1,a2,…,an in the increasing order (1≤a1<a2<…<an<l).
It is guaranteed that the sum of n among all test cases does not exceed 105.
Output
For each test case print a single real number: the time required for cars to meet.
Your answer will be considered correct, if its absolute or relative error does not exceed 10−6. More formally, if your answer is a and jury’s answer is b, your answer will be considered correct if |a−b|max(1,b)≤10−6.
Example
input
5
2 10
1 9
1 10
1
5 7
1 2 3 4 6
2 1000000000
413470354 982876160
9 478
1 10 25 33 239 445 453 468 477
output
3.000000000000000
3.666666666666667
2.047619047619048
329737645.750000000000000
53.700000000000000
Note
In the first test case cars will meet in the coordinate 5.
The first car will be in the coordinate 1 in 1 second and after that its speed will increase by 1 and will be equal to 2 meters per second. After 2 more seconds it will be in the coordinate 5. So, it will be in the coordinate 5 in 3 seconds.
The second car will be in the coordinate 9 in 1 second and after that its speed will increase by 1 and will be equal to 2 meters per second. After 2 more seconds it will be in the coordinate 5. So, it will be in the coordinate 5 in 3 seconds.
In the second test case after 1 second the first car will be in the coordinate 1 and will have the speed equal to 2 meters per second, the second car will be in the coordinate 9 and will have the speed equal to 1 meter per second. So, they will meet after 9−12+1=83 seconds. So, the answer is equal to 1+83=113.
题意: 有一条长度为l的路,两个人分别从路的两头出发,这条路上有n个卡,每经过一个卡,他们的速度就会加1,问:经过多长时间他两会相遇。
题解: 二分查找,从路程的最中间开始查找,一直找到他两所花销时间相等的地点。
c++ AC 代码
#include<bit/stdc++.h>
using namespace std;
const int maxn = 1e5 + 10;
ouble a[maxn];
int n, L;
double get1(double mid)
{
double pre = 0;
double t = 0;
double speed = 1.0;
for (int i = 1; i <= n; i++)
{
if (a[i] <= mid)
{
t += (a[i] - pre) / speed;
pre = a[i];
}
else
break;
speed += 1.0;
}
t += (mid - pre) / speed;
return t;
}
double get2(double mid)
{
double pre = L;
double t = 0;
double speed = 1.0;
for (int i = n; i >= 1; i--)
{
if (a[i] >= mid)
{
t += (pre - a[i]) / speed;
pre = a[i];
}
else
break;
speed += 1.0;
}
t += (pre - mid) / speed;
return t;
}
int main()
{
int t;
scanf("%d", &t);
while (t--)
{
scanf("%d%d", &n, &L);
for (int i = 1; i <= n; i++)
scanf("%lf", &a[i]);
double l = 0, r = L;
while (r - l > 1e-6)
{
double mid = (l + r) / 2;
double t1 = get1(mid);
double t2 = get2(mid);
if (t1 < t2)
l = mid;
else
r = mid;
}
printf("%.10f\n", get1(l));
}
// system("pause");
return 0;
}
文章参考自:(✿◕‿◕✿)