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

T9的空間

You will never walk alone!

  C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
  69 隨筆 :: 0 文章 :: 28 評論 :: 0 Trackbacks

判斷兩個凸多邊形是否相交。做比賽的時候沒有判斷是否兩個多邊形可以包含,wa!貼上去當(dāng)作模板吧

  1#include<iostream>
  2#include<algorithm>
  3#include<cmath>
  4using namespace std;
  5
  6const int oo=0x7fffffff;
  7const double eps=1e-6;
  8
  9void pass() {cout<<"passpasspasspass"<<endl;}
 10template<class T> void print (T a) {cout<<a<<endl;}
 11template<class T> void print (T a,int n) {for(int i=0;i<n;i++) cout<<a[i]<<" "; cout<<endl;}
 12template<class T> T gmax(T a,T b) {return a>b?a:b;}
 13template<class T> T gmin(T a,T b) {return a>b?b:a;}
 14template<class T> T square (T a) {return a*a;}
 15
 16const int MaxP=2005;
 17
 18//平面點
 19typedef struct TPoint
 20{
 21    double x,y;
 22    TPoint(double _x=0.0,double _y=0.0):x(_x),y(_y){}
 23}
TPoint;
 24
 25TPoint p0;
 26int ch[2005];
 27int top;
 28
 29//平面直線(非方程)
 30typedef struct Line1
 31{
 32    TPoint s;
 33    TPoint e;
 34    Line1(TPoint _s,TPoint _e):s(_s),e(_e){}
 35}
Line1;
 36
 37//平面多邊形
 38typedef struct Poly
 39{
 40    TPoint p[MaxP];
 41    int n;
 42}
Poly;
 43
 44//平面點的距離
 45double dist(TPoint a,TPoint b)
 46{
 47    return square(a.x-b.x)+square(a.y-b.y);
 48}

 49
 50//p0p1 cross p0p2
 51double cross(TPoint p0,TPoint p1,TPoint p2)
 52{
 53    return (p1.x-p0.x)*(p2.y-p0.y)-(p1.y-p0.y)*(p2.x-p0.x);
 54}

 55
 56
 57//兩條直線是否相交
 58bool isins(TPoint s1,TPoint e1,TPoint s2,TPoint e2)
 59{
 60    if(gmax(s1.x,e1.x)>=gmin(s2.x,e2.x)&& 
 61        gmax(s2.x,e2.x)>=gmin(s1.x,e1.x)&&
 62        gmax(s1.y,e1.y)>=gmin(s2.y,e2.y)&&
 63        gmax(s2.y,e2.y)>=gmin(s1.y,e1.y)&&
 64        cross(s1,s2,e1)*cross(s1,e1,e2)>=0&&
 65        cross(s2,s1,e2)*cross(s2,e2,e1)>=0)
 66        return true;
 67    else return false;
 68}

 69
 70//判斷點是否在多邊形內(nèi)部利用面積是否相等
 71bool inpoly(TPoint p,Poly a)
 72{
 73    int i,area1=0,area2=0;
 74    a.p[a.n]=a.p[0];//把p0給pn,便于循環(huán)
 75    for(i=0;i<a.n;i++)
 76        area1+=fabs(cross(p,a.p[i],a.p[i+1]));
 77    for(i=1;i<a.n-1;i++)
 78        area2+=fabs(cross(a.p[0],a.p[i],a.p[i+1]));
 79    if(fabs(area1-area2)<eps)return true;
 80    else return false;
 81}

 82//判斷凸多邊形是否相交
 83bool ins(Poly &a,Poly &b)
 84{
 85    a.p[a.n]=a.p[0];
 86    b.p[b.n]=b.p[0];
 87    int i,j;
 88    for(i=0;i<a.n;i++)
 89        for(j=0;j<b.n;j++)
 90            if(isins(a.p[i],a.p[i+1],b.p[j],b.p[j+1]))
 91                return true;
 92    if(inpoly(a.p[0],b)||inpoly(b.p[0],a))
 93        return true;
 94    return false;
 95}

 96
 97//graham掃描法求凸包
 98bool cmp(TPoint a,TPoint b)
 99{
100    double c=cross(p0,a,b);
101    if(c>0)return true;
102    else if(!c&&dist(p0,b)<dist(p0,a))
103        return true;
104    else return false;
105}

106
107void graham(TPoint p[],int n)
108{
109    int i,se=0;
110    for(i=0;i<n;i++)
111        if(p[i].y<p[se].y||(p[i].y==p[se].y&&p[i].x<p[se].x))
112            se=i;
113    swap(p[se],p[0]);
114    p0=p[0];
115    sort(p+1,p+n,cmp);
116    for(i=0;i<=1;i++) ch[i]=i;
117    top=1;
118    for(i=2;i<n;i++)
119    {
120        while(cross(p[ch[top-1]],p[ch[top]],p[i])<=0)
121        {
122            if(top==1)break;
123            top--;
124        }

125        ch[++top]=i;
126    }

127}

128
129
130TPoint p[MaxP];
131
132int main()
133{
134    int T=1,i,n;
135    double X1,Y1,X2,Y2;
136    int D,P;
137    while(scanf("%d%d",&D,&P)&&(D||P))
138    {
139        for(i=0,n=0;i<D;i++)
140        {
141            scanf("%lf%lf%lf%lf",&X1,&Y1,&X2,&Y2);
142            p[n].x=X1; p[n++].y=Y1;
143            p[n].x=X2; p[n++].y=Y1;
144            p[n].x=X2; p[n++].y=Y2;
145            p[n].x=X1; p[n++].y=Y2;
146        }

147        Poly d;
148        graham(p,n);
149        for(i=0;i<=top;i++)
150            d.p[i]=p[ch[i]];
151        d.n=top+1;
152
153        for(i=0,n=0;i<P;i++)
154        {
155            scanf("%lf%lf%lf%lf",&X1,&Y1,&X2,&Y2);
156            p[n].x=X1; p[n++].y=Y1;
157            p[n].x=X2; p[n++].y=Y1;
158            p[n].x=X2; p[n++].y=Y2;
159            p[n].x=X1; p[n++].y=Y2;
160        }

161        Poly pe;
162        graham(p,n);
163        for(i=0;i<=top;i++)
164            pe.p[i]=p[ch[i]];
165        pe.n=top+1;
166
167        if(ins(d,pe))
168            printf("Case %d: It is not possible to separate the two groups of vendors.\n\n",T++);
169        else 
170            printf("Case %d: It is possible to separate the two groups of vendors.\n\n",T++);
171    }

172    return 0;
173}
posted on 2008-09-07 12:51 Torres 閱讀(397) 評論(0)  編輯 收藏 引用 所屬分類: Computation Geometry
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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视频免费观看| 欧美亚洲在线播放| 久久精品日产第一区二区| 欧美在线亚洲在线| 久久精品噜噜噜成人av农村| 久久婷婷国产综合精品青草| 久久精品色图| 免费欧美电影| 国产精品久久久久久久久久免费 | 欧美一区二区精品| 久久黄色网页| 欧美大片第1页| 日韩视频在线观看免费| 亚洲性图久久| 久久久www免费人成黑人精品 | 久久一区二区视频| 亚洲啪啪91| 亚洲综合成人在线| 久久久国产精品亚洲一区 | 午夜影视日本亚洲欧洲精品| 久久精品一区二区三区中文字幕| 美女国产精品| 国产精品嫩草99a| 亚洲国产成人在线播放| 亚洲一区成人| 欧美国产日韩精品免费观看| 在线视频欧美日韩精品| 久久夜色精品| 国产在线不卡| 中日韩美女免费视频网址在线观看| 欧美在线在线| 亚洲美女电影在线| 久久久蜜臀国产一区二区| 久热国产精品| 亚洲老司机av| 免费日韩av| 国外成人在线| 久久激情中文| 99热精品在线| 欧美成ee人免费视频| 国产一区二区高清| 性xx色xx综合久久久xx| 日韩午夜av在线| 欧美成人影音| 依依成人综合视频| 久久亚洲午夜电影| 香蕉av福利精品导航| 国产精品免费aⅴ片在线观看| 日韩午夜免费视频| 欧美激情性爽国产精品17p| 欧美在线观看视频一区二区三区| 欧美视频国产精品| 一区二区三区四区精品| 亚洲精品韩国| 欧美日韩国产a| 亚洲免费电影在线观看| 亚洲国产精品电影| 欧美激情视频一区二区三区在线播放| 影音先锋一区| 欧美 日韩 国产一区二区在线视频| 午夜精品亚洲| 含羞草久久爱69一区| 久久免费偷拍视频| 久久精品理论片| 永久555www成人免费| 蜜桃av久久久亚洲精品| 久久视频精品在线| 亚洲免费观看高清完整版在线观看| 亚洲国产精品悠悠久久琪琪| 欧美精品一区视频| 亚洲欧美怡红院| 欧美一区二区私人影院日本 | 久久资源av| 亚洲日本一区二区| 亚洲日本va在线观看| 欧美日韩中文字幕在线视频| 亚洲欧美精品| 欧美一区二区三区视频在线| 国产一区二区三区在线观看精品| 久久久久九九视频| 欧美aa在线视频| 亚洲制服欧美中文字幕中文字幕| 亚洲一区精品视频| 影音先锋久久资源网| 夜夜精品视频一区二区| 国产性天天综合网| 亚洲国产99| 国产精品一区二区女厕厕| 免费观看日韩av| 欧美日韩在线播放| 久久婷婷综合激情| 欧美日韩高清不卡| 久久人91精品久久久久久不卡| 亚洲韩国日本中文字幕| 欧美日韩亚洲三区| 久久久国产91| 欧美精品在线免费| 久久久国产亚洲精品| 你懂的一区二区| 香蕉久久夜色精品国产使用方法| 美国三级日本三级久久99| 午夜精品亚洲| 欧美日本在线视频| 久热精品视频在线观看| 国产精品国产三级国产a| 欧美成人xxx| 国产伦精品一区二区三区在线观看| 欧美成人黄色小视频| 国产精品久久7| 亚洲国产精品久久久久| 国产日韩在线亚洲字幕中文| 亚洲国产精品一区二区尤物区| 国产麻豆综合| 在线中文字幕不卡| 99视频在线观看一区三区| 久久黄色级2电影| 欧美中文字幕久久| 国产精品久久久久久久久久免费| 亚洲国产精品一区二区尤物区| 国产在线视频欧美一区二区三区| 一区二区三区精品视频在线观看| 亚洲精品孕妇| 美日韩免费视频| 欧美ab在线视频| 伊人蜜桃色噜噜激情综合| 欧美影院视频| 久久精品免费观看| 国产欧美三级| 欧美一级电影久久| 久久九九精品99国产精品| 国产婷婷色一区二区三区在线| 亚洲免费影视第一页| 久久av最新网址| 国产日韩欧美一区在线| 新狼窝色av性久久久久久| 久久精品99国产精品日本| 国产亚洲精品7777| 久久国产精品久久精品国产| 久久中文精品| 亚洲国产高清自拍| 欧美α欧美αv大片| 亚洲高清影视| 99re66热这里只有精品3直播| 欧美肥婆bbw| 亚洲最快最全在线视频| 亚洲欧美日韩直播| 狠狠色狠狠色综合日日91app| 久久久亚洲成人| 欧美激情亚洲国产| 亚洲一区二区三区在线视频| 国产精品视频yy9299一区| 欧美一区午夜精品| 免费欧美网站| 最近中文字幕mv在线一区二区三区四区 | 亚洲一二三级电影| 国产精品亚洲综合色区韩国| 久久国产精品毛片| 欧美国产欧美亚洲国产日韩mv天天看完整 | 国产亚洲欧美另类中文| 欧美一区亚洲| 亚洲激情视频网站| 亚洲一区在线播放| 国产亚洲一级高清| 媚黑女一区二区| 一本久久青青| 久久国产综合精品| 亚洲人体大胆视频| 国产精品第一区| 久久久亚洲国产美女国产盗摄| 亚洲片国产一区一级在线观看| 亚洲愉拍自拍另类高清精品| 国产亚洲视频在线观看| 欧美不卡视频一区| 亚洲欧美日韩一区在线| 欧美成人一区二区三区在线观看| 中文在线不卡| 曰本成人黄色| 国产麻豆精品theporn| 麻豆精品一区二区综合av| 99国产精品久久久久久久| 久久久国产一区二区三区| 亚洲人成在线观看网站高清| 国产精品一二三| 欧美激情网站在线观看| 久久精品国产精品| 亚洲欧美精品伊人久久| 亚洲全黄一级网站| 六月丁香综合| 欧美淫片网站| 中文精品视频| 亚洲国产日日夜夜| 一区二区三区在线视频免费观看| 国产精品久久久999| 欧美日韩成人| 欧美黄色免费| 久久性色av| 久久久久久亚洲精品不卡4k岛国|