Grakn Forces 2020 C. Discrete Acceleration——二分查找

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 1n105,1l109): 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;
}

文章参考自:(✿◕‿◕✿)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值