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

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)  編輯 收藏 引用 所屬分類: 計算幾何

<2012年7月>
24252627282930
1234567
891011121314
15161718192021
22232425262728
2930311234

導航

統計

公告

常用鏈接

留言簿(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>
            亚洲第一精品夜夜躁人人爽| 亚洲一区二区在线观看视频| 一区二区视频欧美| 欧美日韩国产小视频| 久久久噜久噜久久综合| 一本色道久久综合| 亚洲黄色一区二区三区| 欧美精品日韩一本| 欧美福利网址| 欧美国产日韩在线| 欧美国产精品va在线观看| 男男成人高潮片免费网站| 久久久久88色偷偷免费| 久久精品亚洲一区| 久久久久免费| 欧美成人a∨高清免费观看| 久久综合色综合88| 欧美成人一二三| 欧美国产日本在线| 亚洲高清不卡av| 一区二区三欧美| 一本到12不卡视频在线dvd| 亚洲国产精品久久久久婷婷884| 亚洲高清久久| 1024成人| 一区二区三区回区在观看免费视频| 日韩亚洲在线观看| 亚洲欧美国产不卡| 久久资源av| 亚洲黄色小视频| 亚洲无线视频| 久久精品国产在热久久| 米奇777在线欧美播放| 亚洲图片欧洲图片av| 亚洲性感激情| 欧美成熟视频| 午夜老司机精品| 欧美日韩精品一区二区| 韩国精品在线观看| 午夜精品电影| 99精品国产福利在线观看免费| 久久精品成人一区二区三区| 欧美日韩一区精品| 亚洲人成网站777色婷婷| 欧美一区二区私人影院日本 | 亚洲综合色激情五月| 欧美freesex8一10精品| 午夜久久久久| 国产精品一区二区久久精品| 99re视频这里只有精品| 欧美成人中文| 久久躁狠狠躁夜夜爽| 狠狠色狠色综合曰曰| 久久精品论坛| 欧美在线播放| 国产日韩一区二区三区| 亚洲欧美视频一区二区三区| 99热免费精品| 国产精品免费aⅴ片在线观看| 亚洲欧美成人一区二区在线电影| 亚洲精品欧美日韩专区| 欧美日韩视频一区二区| 亚洲欧美福利一区二区| 亚洲欧美日韩精品久久| 国产三区二区一区久久| 久久久久.com| 麻豆91精品| 亚洲精选在线观看| 亚洲精品一区二区三区蜜桃久| 欧美片在线播放| 亚洲男人第一网站| 欧美亚洲尤物久久| 亚洲成色777777在线观看影院| 欧美成人午夜剧场免费观看| 欧美精品自拍| 欧美在线一二三区| 久久一二三区| 亚洲一区二区在线视频| 亚洲一区日韩在线| 国语自产精品视频在线看抢先版结局| 久久精品视频导航| 欧美午夜大胆人体| 午夜精品视频在线| 久久久一本精品99久久精品66| 亚洲日本aⅴ片在线观看香蕉| 亚洲美女电影在线| 国产日韩欧美日韩大片| 嫩草影视亚洲| 欧美四级在线| 麻豆国产精品一区二区三区| 欧美激情中文字幕乱码免费| 午夜精品福利一区二区蜜股av| 久久国产日韩欧美| 一本色道久久综合亚洲精品不| 亚洲欧美电影在线观看| 亚洲国产二区| 亚洲欧美www| 亚洲精品永久免费精品| 亚洲综合电影一区二区三区| 亚洲人成毛片在线播放| 羞羞色国产精品| 一区二区高清| 久久综合色影院| 欧美在线视频一区二区三区| 欧美激情2020午夜免费观看| 久久成人羞羞网站| 欧美日韩视频一区二区| 欧美高清hd18日本| 国产日韩综合一区二区性色av| 亚洲国产99| 国内视频精品| 亚洲尤物在线视频观看| 在线视频欧美日韩| 久久五月激情| 久久免费高清视频| 国产精品国产馆在线真实露脸| 欧美激情欧美狂野欧美精品| 国产亚洲免费的视频看| 亚洲午夜在线观看| 中文av字幕一区| 欧美日韩精品免费观看视频| 欧美高清不卡| 亚洲国产午夜| 麻豆av一区二区三区久久| 亚洲女同精品视频| 国产精品女人网站| 在线视频亚洲| 亚洲永久免费观看| 欧美日韩一卡二卡| 日韩视频一区二区三区在线播放 | 亚洲一区www| 欧美精品久久久久久久| 欧美激情一区二区三区四区| 伊人久久久大香线蕉综合直播| 午夜精品成人在线视频| 性感少妇一区| 国产丝袜一区二区三区| 午夜免费在线观看精品视频| 久久9热精品视频| 国产精品日韩| 午夜国产精品视频免费体验区| 香蕉久久夜色精品国产| 国产精品毛片高清在线完整版| 一区二区三区鲁丝不卡| 午夜精品www| 久久精品国产亚洲一区二区三区| 国产精品网站一区| 亚洲一区二区三区777| 欧美一区1区三区3区公司| 国产精品日韩久久久| 亚洲欧美亚洲| 欧美成人精品一区| 亚洲国产网站| 欧美日韩在线一区二区| 亚洲自拍三区| 老鸭窝亚洲一区二区三区| 亚洲黄色在线视频| 欧美日韩精品一区二区天天拍小说| 一本大道久久a久久精二百| 欧美一区二区| 亚洲精品1区2区| 欧美日韩喷水| 久久精品毛片| 亚洲久久一区二区| 欧美在线一二三区| 亚洲精品小视频在线观看| 国产精品都在这里| 欧美一级成年大片在线观看| 欧美岛国激情| 亚洲欧美在线一区| 亚洲国产福利在线| 国产精品久久久久久久app| 久久精品色图| 亚洲图片自拍偷拍| 欧美91精品| 久久国产日韩欧美| 一区二区三区福利| 黄网站免费久久| 国产精品乱子乱xxxx| 免费中文字幕日韩欧美| 欧美一进一出视频| 亚洲精品影视| 久久艳片www.17c.com| 亚洲在线观看视频网站| 亚洲国产高清aⅴ视频| 国产精品素人视频| 欧美久久久久久久久| 久久精品系列| 午夜天堂精品久久久久| 日韩视频在线观看免费| 免费日韩成人| 久久天天躁狠狠躁夜夜av| 午夜一区不卡| 亚洲视频一区二区在线观看| 亚洲国产精品va在看黑人| 国产亚洲精品久久久| 国产女人精品视频| 国产精品看片资源| 欧美午夜片欧美片在线观看| 欧美日韩国产综合视频在线观看|