青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

二分水面高度,然后求總水量(就是求多邊形面積)

/*************************************************************************
Author: WHU_GCC
Created Time: 2007-8-10 13:49:09
File Name: pku3334.cpp
Description: 
***********************************************************************
*/

#include 
<algorithm>
#include 
<iostream>
#include 
<sstream>
#include 
<string>
#include 
<queue>
#include 
<list>
#include 
<set>
#include 
<map>
#include 
<cmath>
#include 
<vector>
#include 
<cctype>
#include 
<cstring>
using namespace std;
#define out(x) (cout<<#x<<": "<<x<<endl)
const int maxint=0x7FFFFFFF;
const long long maxlonglong=0x7FFFFFFFFFFFFFFFLL;
const double inf = 1e200;
const double eps = 1e-9;
template
<class T>void show(T a, int n){for(int i=0; i<n; ++i) cout<<a[i]<<' '; cout<<endl;}
template
<class T>void show(T a, int r, int l){for(int i=0; i<r; ++i)show(a[i],l);cout<<endl;}

const int maxn = 2000;

typedef 
struct
{
    
double x, y;
}
 point_t;

point_t ga[maxn], gb[maxn];
int cnt_ga, cnt_gb;
int bottom_a, bottom_b;
int v_water;

point_t p[maxn];
int cnt_p;

double cross(point_t a, point_t b)
{
    
return a.x * b.y - a.y * b.x;
}


double count_area()
{
    
double ret = 0.0;
    
for (int i = 0; i < cnt_p; i++)
    
{
        ret 
+= cross(p[i], p[(i + 1% cnt_p]) / 2.0;
    }

    
return ret;
}


bool ok(double h)
{
    
double area = 0.0;
    cnt_p 
= 0;
    
for (int i = 0; i < bottom_a; i++)
    
{
        
if (cnt_p > 0)
        
{
            p[cnt_p] 
= ga[i];
            cnt_p
++;
        }

        
if (ga[i].y >= h && ga[i + 1].y < h)
        
{
            
double t = (ga[i].y - h) / (h - ga[i + 1].y);
            
double x = (ga[i].x + t * ga[i + 1].x) / (t + 1);
            p[
0].x = x;
            p[
0].y = h;
            cnt_p
++;
        }

    }

    
for (int i = bottom_a; i < cnt_ga; i++)
    
{
        
if (cnt_p > 0)
        
{
            p[cnt_p] 
= ga[i];
            cnt_p
++;
        }

        
if (ga[i].y < h && ga[i + 1].y >= h)
        
{
            
double t = (ga[i].y - h) / (h - ga[i + 1].y);
            
double x = (ga[i].x + t * ga[i + 1].x) / (t + 1);
            p[cnt_p].x 
= x;
            p[cnt_p].y 
= h;
            cnt_p
++;
            
break;
        }

    }

    area 
+= count_area();
    cnt_p 
= 0;
    
for (int i = 0; i < bottom_b; i++)
    
{
        
if (cnt_p > 0)
        
{
            p[cnt_p] 
= gb[i];
            cnt_p
++;
        }
        
        
if (gb[i].y >= h && gb[i + 1].y < h)
        
{
            
double t = (gb[i].y - h) / (h - gb[i + 1].y);
            
double x = (gb[i].x + t * gb[i + 1].x) / (t + 1);
            p[
0].x = x;
            p[
0].y = h;
            cnt_p
++;
        }

    }

    
for (int i = bottom_b; i < cnt_gb; i++)
    
{
        
if (cnt_p > 0)
        
{
            p[cnt_p] 
= gb[i];
            cnt_p
++;
        }

        
if (gb[i].y < h && gb[i + 1].y >= h)
        
{
            
double t = (gb[i].y - h) / (h - gb[i + 1].y);
            
double x = (gb[i].x + t * gb[i + 1].x) / (t + 1);
            p[cnt_p].x 
= x;
            p[cnt_p].y 
= h;
            cnt_p
++;
            
break;
        }

    }

    area 
+= count_area();
    
if (area >= v_water) return false;
    
else return true;
}



double work()
{
    
double up, down;
    up 
= min(min(ga[0].y, ga[cnt_ga - 1].y), min(gb[0].y, gb[cnt_gb - 1].y));
    
double t1 = inf, t2 = inf;
    
for (int i = 0; i < cnt_ga; i++if (ga[i].y < t1)
    
{
        t1 
= ga[i].y;
        bottom_a 
= i;
    }

    
for (int i = 0; i < cnt_gb; i++if (gb[i].y < t2)
    
{
        t2 
= gb[i].y;
        bottom_b 
= i;
    }

    down 
= min(t1, t2);
    
    
while (fabs(up - down) > eps)
    
{
        
double mid = (up + down) / 2.0;
        
if (ok(mid))
            down 
= mid;
        
else up = mid;
    }

    
return up;
}


int main()
{
    
int ca;
    
for (scanf("%d"&ca); ca--;)
    
{
        scanf(
"%d"&v_water);
        scanf(
"%d"&cnt_ga);
        
for (int i = 0; i < cnt_ga; i++) scanf("%lf%lf"&ga[i].x, &ga[i].y);
        scanf(
"%d"&cnt_gb);
        
for (int i = 0; i < cnt_gb; i++) scanf("%lf%lf"&gb[i].x, &gb[i].y);
        
double ans = work();
        printf(
"%.3lf\n", ans);
    }

    
return 0;
}
posted on 2007-08-15 08:59 Felicia 閱讀(474) 評論(1)  編輯 收藏 引用 所屬分類: 計算幾何
Comments
  • # re: [計算幾何]pku3334
    babt
    Posted @ 2011-05-14 15:42
    代碼有點小問題。
    這組數據過不去。
    31
    6
    -45 23 -40 22 -30 20 -20 19 -10 18 -5 22
    6
    0 22 10 21 20 20 30 19 40 20 42 22
    應該是19.964  回復  更多評論   
 
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美激情一二区| 久久在线精品| av成人天堂| 久久都是精品| 亚洲中字黄色| 嫩草国产精品入口| 久久激情五月婷婷| 欧美日韩精品免费观看视一区二区| 久久成人人人人精品欧| 欧美另类一区二区三区| 麻豆久久精品| 国产一区二区中文| 亚洲特色特黄| 在线亚洲精品福利网址导航| 免费高清在线一区| 久久久久久久高潮| 国产欧美日韩精品丝袜高跟鞋| 亚洲精品韩国| 亚洲电影自拍| 久久精品中文| 久久一区二区三区av| 国产欧美日韩| 性8sex亚洲区入口| 久久国产精品久久精品国产| 国产精品高潮呻吟久久| 亚洲美女电影在线| av成人手机在线| 欧美日韩福利| av成人免费在线| 正在播放日韩| 欧美午夜精品理论片a级按摩| 91久久久精品| 一区二区久久| 欧美三级小说| 亚洲男女毛片无遮挡| 亚洲男女自偷自拍| 国产精品久久久一区二区三区| 99国产精品久久久久老师| 一区二区电影免费在线观看| 欧美另类一区二区三区| 一道本一区二区| 亚洲一区二三| 国产热re99久久6国产精品| 欧美一区永久视频免费观看| 久久久女女女女999久久| 精品成人乱色一区二区| 欧美ed2k| 9i看片成人免费高清| 欧美一区二区三区四区在线| 国产日韩欧美在线视频观看| 久久久久国产精品人| 欧美国产日韩一区二区| 亚洲视频免费在线| 国产女人18毛片水18精品| 久久久久se| 亚洲高清在线精品| 午夜激情亚洲| 在线精品国产成人综合| 欧美理论大片| 久久精品国产2020观看福利| 亚洲国产日韩欧美在线99| 亚洲男人的天堂在线aⅴ视频| 国产视频久久网| 蜜桃精品久久久久久久免费影院| 日韩视频在线你懂得| 久久狠狠亚洲综合| 亚洲免费黄色| 国产日韩一区二区| 欧美黄色网络| 欧美呦呦网站| 亚洲免费av片| 欧美va亚洲va香蕉在线| 亚洲欧美国产一区二区三区| 亚洲国产一区二区精品专区| 国产精品视频成人| 欧美极品色图| 久久久噜噜噜久噜久久| 亚洲一级二级在线| 亚洲高清久久网| 久久久久久九九九九| 亚洲在线播放电影| 亚洲精品国产精品国自产在线 | 9l视频自拍蝌蚪9l视频成人| 国产亚洲精品aa| 欧美三级网址| 欧美久久久久久久| 蜜桃久久av一区| 欧美在线一区二区| 亚洲一区在线播放| 亚洲卡通欧美制服中文| 欧美阿v一级看视频| 久久久久久久一区二区| 亚洲综合电影| 中文在线不卡| 亚洲精品一区久久久久久| 在线观看亚洲精品视频| 国产久一道中文一区| 欧美视频在线看| 欧美日韩午夜在线| 美女免费视频一区| 久久久国际精品| 久久成人亚洲| 久久精品日产第一区二区| 亚洲欧美激情精品一区二区| 一区二区三区久久久| 亚洲美女毛片| 日韩一级片网址| 99视频一区| 一区二区日韩免费看| 亚洲区欧美区| 亚洲久久一区| 一本色道久久加勒比精品| 夜夜嗨av一区二区三区中文字幕| 亚洲欧洲精品一区二区三区| 亚洲精品1区| 日韩午夜三级在线| 亚洲午夜久久久| 亚洲小少妇裸体bbw| 亚洲欧美激情视频在线观看一区二区三区 | 亚洲综合日韩中文字幕v在线| 亚洲最黄网站| 亚洲淫性视频| 欧美亚洲在线| 久久综合伊人77777蜜臀| 蜜桃av噜噜一区| 免费观看亚洲视频大全| 欧美国产丝袜视频| 亚洲精品乱码久久久久久蜜桃麻豆| 欧美国产亚洲另类动漫| 亚洲精品国精品久久99热| 日韩一级片网址| 亚洲一区观看| 久久久久久久999| 欧美成年人在线观看| 欧美日本精品在线| 国产乱码精品| 亚洲国产精品精华液网站| 在线亚洲免费| 久久久久久久网站| 亚洲黄色免费电影| 亚洲一区二区在线看| 久久久精品tv| 欧美另类综合| 国产一区二区三区免费不卡 | 国产又爽又黄的激情精品视频 | 亚洲欧美999| 久久久久国色av免费观看性色| 欧美电影免费观看网站| 日韩西西人体444www| 欧美一区免费视频| 你懂的视频一区二区| 国产精品嫩草99av在线| 在线观看欧美一区| 亚洲综合成人在线| 欧美成人免费全部| 一区二区三区日韩在线观看| 亚洲精品久久久久久久久久久| 亚洲影院免费观看| 蜜桃视频一区| 亚洲性人人天天夜夜摸| 久久综合九色综合久99| 国产精品色在线| 日韩亚洲综合在线| 久久久久久久久综合| av不卡在线观看| 米奇777在线欧美播放| 国产乱码精品一区二区三区忘忧草 | 在线一区二区三区做爰视频网站| 久久精品二区亚洲w码| 国产精品国产三级国产专播精品人 | 欧美xxx在线观看| 国产视频在线观看一区二区| 99国内精品久久久久久久软件| 久久天堂精品| 午夜国产不卡在线观看视频| 欧美日韩视频在线一区二区| 亚洲高清三级视频| 久久免费少妇高潮久久精品99| 这里只有精品丝袜| 欧美久久综合| 亚洲精品在线观看视频| 模特精品在线| 久久久精品国产99久久精品芒果| 国产精品久久毛片a| 在线视频欧美日韩| 亚洲日本激情| 欧美v国产在线一区二区三区| 狠狠色狠狠色综合人人| 久久久久久噜噜噜久久久精品| 亚洲一区二区三区精品视频| 欧美三级韩国三级日本三斤| 亚洲人成人77777线观看| 免费观看成人| 久热精品在线视频| 亚洲国产日韩欧美| 欧美成人精品在线观看| 蜜臀91精品一区二区三区| 亚洲国产日韩一区二区| 欧美激情精品久久久久久久变态 | 亚洲片区在线|