简单几何题,但是容易WA。做法是二分水面高度,然后看看这个高度对应多少水。

 /**//*************************************************************************
/**//*************************************************************************
 Author: WHU_GCC
Author: WHU_GCC
 Created Time: 2007-9-5 20:34:00
Created Time: 2007-9-5 20:34:00
 File Name: pku1434.cpp
File Name: pku1434.cpp
 Description:
Description: 
 ************************************************************************/
************************************************************************/
 #include <iostream>
#include <iostream>
 using namespace std;
using namespace std;

 #define out(x) (cout << #x << ": " << x << endl)
#define out(x) (cout << #x << ": " << x << endl)
 typedef long long int64;
typedef long long int64;
 const int maxint = 0x7FFFFFFF;
const int maxint = 0x7FFFFFFF;
 const int64 maxint64 = 0x7FFFFFFFFFFFFFFFLL;
const int64 maxint64 = 0x7FFFFFFFFFFFFFFFLL;

 template <class T> void show(T a, int n)
template <class T> void show(T a, int n)  { for (int i = 0; i < n; ++i) cout << a[i] << ' '; cout << endl; }
{ for (int i = 0; i < n; ++i) cout << a[i] << ' '; cout << endl; }

 template <class T> void show(T a, int r, int l)
template <class T> void show(T a, int r, int l)  { for (int i = 0; i < r; ++i) show(a[i], l); cout << endl; }
{ for (int i = 0; i < r; ++i) show(a[i], l); cout << endl; }

 const int maxn = 50010;
const int maxn = 50010;
 const double eps = 1e-3;
const double eps = 1e-3;

 typedef struct tank_t
typedef struct tank_t


 {
{
 int b, h, w, d;
    int b, h, w, d;
 };
};

 int n;
int n;
 tank_t tank[maxn];
tank_t tank[maxn];
 double water;
double water;

 int ok(double mid)
int ok(double mid)


 {
{
 double sum = 0.0;
    double sum = 0.0;
 for (int i = 0; i < n; i++)
    for (int i = 0; i < n; i++)

 
     {
{
 if (tank[i].b < mid && mid < tank[i].b + tank[i].h)
        if (tank[i].b < mid && mid < tank[i].b + tank[i].h)
 sum += tank[i].w * tank[i].d * (mid - tank[i].b);
            sum += tank[i].w * tank[i].d * (mid - tank[i].b);
 if (tank[i].b + tank[i].h <= mid)
        if (tank[i].b + tank[i].h <= mid)
 sum += tank[i].w * tank[i].d * tank[i].h;
            sum += tank[i].w * tank[i].d * tank[i].h;
 }
    }
 return sum < water;
    return sum < water;
 }
}

 double solve()
double solve()


 {
{
 double up = 0.0, down = 1e10;
    double up = 0.0, down = 1e10;
 
    
 for (int i = 0; i < n; i++)
    for (int i = 0; i < n; i++)

 
     {
{
 up >?= tank[i].b + tank[i].h;
        up >?= tank[i].b + tank[i].h;
 down <?= tank[i].b;
        down <?= tank[i].b;
 }
    }
 if (ok(up))
    if (ok(up))
 return -1;
        return -1;

 double mid;
    double mid;

 while (up - down > eps)
    while (up - down > eps)

 
     {
{
 mid = (up + down) / 2.0;
        mid = (up + down) / 2.0;
 if (ok(mid))
        if (ok(mid))
 down = mid;
            down = mid;
 else
        else
 up = mid;
            up = mid;
 }
    }
 if (ok(down))
    if (ok(down))
 return down;
        return down;
 else
    else
 return up;
        return up;
 }
}

 int main()
int main()


 {
{
 int ca;
    int ca;
 for (scanf("%d", &ca); ca--;)
    for (scanf("%d", &ca); ca--;)

 
     {
{
 scanf("%d", &n);
        scanf("%d", &n);
 for (int i = 0; i < n; i++)
        for (int i = 0; i < n; i++)
 scanf("%d%d%d%d", &tank[i].b, &tank[i].h, &tank[i].w, &tank[i].d);
            scanf("%d%d%d%d", &tank[i].b, &tank[i].h, &tank[i].w, &tank[i].d);
 scanf("%lf", &water);
        scanf("%lf", &water);
 double ans = solve();
        double ans = solve();
 if (ans < 0)
        if (ans < 0)
 printf("OVERFLOW\n");
            printf("OVERFLOW\n");
 else
        else
 printf("%.2lf\n", ans);
            printf("%.2lf\n", ans);
 }
    }
 return 0;
    return 0;
 }
}