B. Olympic Medal

time limit per test
2 seconds
memory limit per test
256 megabytes
input
standard input
output
standard output

The World Programming Olympics Medal is a metal disk, consisting of two parts: the first part is a ring with outer radius of r1 cm, inner radius of r2 cm, (0 < r2 < r1) made of metal with density p1 g/cm3. The second part is an inner disk with radius r2 cm, it is made of metal with density p2 g/cm3. The disk is nested inside the ring.

The Olympic jury decided that r1 will take one of possible values of x1, x2, ..., xn. It is up to jury to decide which particular value r1 will take. Similarly, the Olympic jury decided that p1 will take one of possible value of y1, y2, ..., ym, and p2 will take a value from listz1, z2, ..., zk.

According to most ancient traditions the ratio between the outer ring mass mout and the inner disk mass min must equal , where A, B are constants taken from ancient books. Now, to start making medals, the jury needs to take values forr1p1p2 and calculate the suitable value of r2.

The jury wants to choose the value that would maximize radius r2. Help the jury find the sought value of r2. Value r2 doesn't have to be an integer.

Medal has a uniform thickness throughout the area, the thickness of the inner disk is the same as the thickness of the outer ring.

Input

The first input line contains an integer n and a sequence of integers x1, x2, ..., xn. The second input line contains an integer m and a sequence of integers y1, y2, ..., ym. The third input line contains an integer k and a sequence of integers z1, z2, ..., zk. The last line contains two integers A and B.

All numbers given in the input are positive and do not exceed 5000. Each of the three sequences contains distinct numbers. The numbers in the lines are separated by spaces.

Output

Print a single real number — the sought value r2 with absolute or relative error of at most 10 - 6. It is guaranteed that the solution that meets the problem requirements exists.

Sample test(s)
input
3 1 2 3
1 2
3 3 2 1
1 2
output
2.683281573000
input
4 2 3 6 4
2 1 2
3 10 6 8
2 1
output
2.267786838055
Note

In the first sample the jury should choose the following values: r1 = 3p1 = 2p2 = 1.



解题说明:此题是找出满足条件的最大的半径,用贪心加上数学公式即可求解。


#include <iostream>
#include<algorithm>
#include<cstdio>
#include<cmath>
#include<cstring>
using namespace std;

int main()
{
	int x,i,r1=0,a,p1=0,p2,y,z;
	scanf("%d",&x);
	for(i=1;i<=x;i++)
	{
		scanf("%d",&a);
		if(a>r1)
		{
			r1=a;
		}
	}
	scanf("%d",&x);
	for(i=1;i<=x;i++)
	{
		scanf("%d",&a);
		if(a>p1)
		{
			p1=a;
		}
	}
	scanf("%d%d",&x,&p2);
	for(i=1;i<x;i++)
	{
		scanf("%d",&a);
		if(a<p2)
		{
			p2=a;
		}
	}
	scanf("%d%d",&y,&z);
	double j=(double)y/z;
	double r2=r1/pow((((j*p2)/p1)+1),0.5);
	printf("%lf",r2);
	return 0;
}


你可能感兴趣的:(B. Olympic Medal)