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

poj 3130 How I Mathematician Wonder What You Are!

   半平面交的一個題,也是求多邊形的核心。求出這個好像也可以用于解決一些線性規劃問題。我用的是N*N的基本算法,每加入一條直線,
就對原來求出的半平面交進行處理,產生新的核心。
   代碼參照臺灣的一個網站演算法筆記上的內容和代碼。表示這個網站巨不錯,求凸包的算法也參照了這個網站上的內容和代碼。
半平面交的地址:http://www.csie.ntnu.edu.tw/~u91029/Half-planeIntersection.html#a4
   
   代碼思路主要是:先讀入所有的多邊形頂點,放入一個vector(vp)里面,然后對多邊形的每條邊求一個半平面。剛開始的時候,用一個
vector(Polygon)保存代表上下左右四個無限遠角的四個點,表示原始的半平面。然后,用讀入的多邊形的每條邊去切割原來的半平面。
切割的過程是,如果原來(Polygon)中的點在當前直線的指定一側,那么原來的點還是有效的。如果原來的點和它相鄰的下一個點與當前
直線相交,那么還需要把交點加入Polygon集合。
   還有求交點的方法比較奇葩,類似于黑書上面的那種根據面積等分的方法。

   代碼如下:
#include <stdio.h>
#include <string.h>
#include <math.h>
#include <vector>
#include <algorithm>
using namespace std;

double fPre = 1e-8;
struct Point
{
    double x;
    double y;
    Point(){}
    Point(double fX, double fY)
    {
        x = fX, y = fY;
    }
};
typedef vector<Point> Polygon;
typedef pair<Point, Point> Line;
Point operator+(const Point& a, const Point& b)
{
    Point t;
    t.x = a.x + b.x;
    t.y = a.y + b.y;
    return t;
}

Point operator-(const Point& a, const Point& b)
{
    Point t;
    t.x = a.x - b.x;
    t.y = a.y - b.y;
    return t;
}

Point operator*(Point a, double fD)
{
    Point t;
    t.x = a.x * fD;
    t.y = a.y * fD;
    return t;
}

int DblCmp(double fD)
{
    return fabs(fD) < fPre ? 0 : (fD > 0 ? 1 : -1);
}

double Det(double fX1, double fY1, double fX2, double fY2)
{
    return fX1 * fY2 - fX2 * fY1;
}
//3點叉積
double Cross(Point a, Point b, Point c)
{
    return Det(b.x - a.x, b.y - a.y, c.x - a.x, c.y - a.y);
}
//向量叉積
double Cross(Point a, Point b)
{
    return a.x * b.y - a.y * b.x;
}

//求直線交點的一種簡便方法
//平行四邊形面積的比例等于高的比例
Point Intersection(Point a1, Point a2, Point b1, Point b2)
{
    Point a = a2 - a1;
    Point b = b2 - b1;
    Point s = b1 - a1;
    
    return a1 + a * (Cross(b, s) / Cross(b, a));
}

Polygon HalfPlane(Polygon& pg, Point a, Point b)
{
    Polygon pgTmp;
    int nN = pg.size();
    for (int i = 0; i < nN; ++i)
    {
        double fC = Cross(a, b, pg[i]);
        double fD = Cross(a, b, pg[(i + 1) % nN]);
        if (DblCmp(fC) >= 0)
        {
            pgTmp.push_back(pg[i]);
        }
        if (fC * fD < 0)
        {
            pgTmp.push_back(Intersection(a, b, pg[i], pg[(i + 1) % nN]));
        }
    }
    return pgTmp;
}

int main()
{
    int nN;
    Point p;
    vector<Point> vp;
    Polygon pg;
    
    while (scanf("%d", &nN), nN)
    {
        vp.clear();
        for (int i = 0; i < nN; ++i)
        {
            scanf("%lf%lf", &p.x, &p.y);
            vp.push_back(p);
        }
        pg.clear();
        pg.push_back(Point(-1e9, 1e9));
        pg.push_back(Point(-1e9, -1e9));
        pg.push_back(Point(1e9, -1e9));
        pg.push_back(Point(1e9, 1e9));
        for (int i = 0; i < nN; ++i)
        {
            pg = HalfPlane(pg, vp[i], vp[(i + 1) % nN]);
            if (pg.size() == 0)
            {
                printf("0\n");
                break;
            }
        }
        if (pg.size())
        {
            printf("1\n");
        }
    }

    return 0;
}

posted on 2012-07-23 10:41 yx 閱讀(1049) 評論(0)  編輯 收藏 引用 所屬分類: 計算幾何

<2025年10月>
2829301234
567891011
12131415161718
19202122232425
2627282930311
2345678

導航

統計

公告

常用鏈接

留言簿(3)

隨筆分類

隨筆檔案

me

好友

同學

網友

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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免费观看性色| 一区二区三区视频在线播放| 亚洲欧洲精品一区二区三区| 久久美女性网| 欧美成人午夜激情在线| 欧美高清视频在线播放| 亚洲第一视频| 91久久国产综合久久91精品网站| 国产亚洲成av人在线观看导航| 国产伦精品一区二区三区视频黑人 | 欧美一级免费视频| 久久av一区二区三区漫画| 亚洲专区一区二区三区| 一本久道久久综合狠狠爱| 亚洲中字黄色| 亚洲第一在线| 国产精品videossex久久发布| 99精品国产在热久久婷婷| 亚洲一区网站| 国产精品激情电影| 国产亚洲在线观看| 亚洲精品国精品久久99热| 欧美在线黄色| 一本色道久久综合| 欧美成人69av| 欧美在线999| 欧美日本一区二区三区| 99精品福利视频| 亚洲精品系列| 亚洲国产小视频在线观看| 亚洲一区二区高清| 欧美精品日韩一本| 亚洲精品国产日韩| 在线观看欧美激情| 久久久久高清| 午夜日本精品| 欧美日韩免费一区| 一区二区三区视频观看| 亚洲人www| 欧美伊人影院| 亚洲高清电影| 欧美日韩国产黄| 亚洲无限av看| 久久香蕉国产线看观看网| 欧美日韩国产精品成人| 亚洲无亚洲人成网站77777 | 国产精品xvideos88| 老色鬼久久亚洲一区二区| 在线观看欧美日韩国产| 91久久国产自产拍夜夜嗨| 媚黑女一区二区| 亚洲特色特黄| 久久九九热re6这里有精品| 欧美国产一区在线| 欧美国产高清| 久久蜜桃香蕉精品一区二区三区| 亚洲高清视频在线观看| 蜜桃久久av一区| 欧美日韩极品在线观看一区| 午夜精品福利在线观看| 另类尿喷潮videofree| 亚洲一区二区欧美日韩| 久久在线免费观看| 欧美日韩小视频| 欧美www视频| 国内自拍一区| 午夜伦欧美伦电影理论片| 亚洲精品久久久久久下一站 | 欧美成人黑人xx视频免费观看| 欧美日韩一区二区在线| 久久综合图片| 国内精品久久久久久久97牛牛| 国产精品久久久久久久久免费桃花| 国产女人精品视频| 亚洲香蕉在线观看| 欧美一二区视频| 亚洲欧美日产图| 亚洲综合日韩中文字幕v在线| 欧美国产视频一区二区| 亚洲人www| 欧美一区二区在线看| 亚洲欧洲另类国产综合| 欧美**字幕| 99国产精品久久久久久久久久 | 久久综合电影| 香蕉久久夜色精品国产使用方法| 狠狠干综合网| 欧美3dxxxxhd| 亚洲调教视频在线观看| 欧美在线影院| 亚洲啪啪91| 国产精品夜夜夜| 久久影院午夜论| 亚洲欧洲一区| 久久av一区二区三区漫画| 在线观看视频一区二区| 免费一区视频| 亚洲国产精品福利| 欧美吻胸吃奶大尺度电影| 午夜亚洲视频| 亚洲免费av网站| 美女日韩欧美| 久久成人一区| 一区二区三区视频在线播放| 99国产精品视频免费观看| 欧美激情在线| 久久蜜桃香蕉精品一区二区三区| 欧美激情一二三区| 国产精品成人免费视频| 亚洲第一色中文字幕| 一区二区三区国产精品| 尤物99国产成人精品视频| 国产精品久久久免费| 欧美成人嫩草网站| 美女视频黄a大片欧美| 欧美在线资源| 欧美一区二区视频在线| 亚洲一级免费视频| 日韩视频国产视频| 欧美大片一区二区| 欧美91视频| 91久久极品少妇xxxxⅹ软件| 欧美一区二区三区视频| 欧美日韩国产色视频| 中日韩美女免费视频网址在线观看 | 亚洲国产99精品国自产| 免费在线看一区| 欧美电影免费观看大全| 久久久久在线| 亚洲国产精品精华液2区45| 亚洲第一在线综合在线| 亚洲免费播放| 久久综合九色欧美综合狠狠| 欧美国产精品久久| 国产精品萝li| 亚洲精选在线观看| 国产一区二区看久久| 亚洲激情网站免费观看| 亚洲一区欧美二区| 久久亚洲综合| 国产精品99久久99久久久二8| 先锋影音网一区二区| 欧美成人伊人久久综合网| 欧美亚一区二区| 99国产精品久久久久久久| 午夜精品久久久久久久久久久久| 欧美成人午夜激情| 香蕉久久夜色精品| 国产精品久久久久久久久久尿| 韩国av一区二区三区四区| 亚洲一区国产视频| 亚洲毛片在线看| 欧美精品99| 亚洲人成在线观看网站高清| 久久国产精品99精品国产| 妖精视频成人观看www| 99视频在线精品国自产拍免费观看| 欧美大片在线观看| 久久人人97超碰国产公开结果 | 午夜一区二区三区不卡视频| 欧美女同视频| 亚洲毛片播放| 宅男在线国产精品| 国产精品婷婷| 欧美电影在线播放| 国产精品久在线观看| 久久精品一二三区| 免费在线欧美黄色| 亚洲综合三区| 久久综合精品国产一区二区三区| 在线观看欧美视频| 一区二区三区久久久| 国产香蕉久久精品综合网| 欧美亚洲在线观看| 欧美日韩高清在线观看| 欧美一区二区在线| 久久久午夜视频| 亚洲欧美卡通另类91av| 久久久久久久激情视频| 在线视频日韩| 久久久天天操| 欧美在线播放视频| 欧美日韩免费一区二区三区| 久久精品国产一区二区三区| 欧美日韩精品在线视频| 久久久欧美一区二区| 国产精品美女主播在线观看纯欲| 久久综合激情| 在线 亚洲欧美在线综合一区| 一区二区欧美视频| 夜夜嗨av一区二区三区中文字幕|