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

隨筆-21  評論-10  文章-21  trackbacks-0
如何快速的計算線段和多邊形(內部)是否相交?
判線段相交要采用快速排斥來加速
用遞歸的想法做, 就轉化成判線段與梯形是否相交
  1 #include<iostream>
  2 #include<vector>
  3 #include<cstdio>
  4 using namespace std;
  5 const double EPS = 1e-8// 給梯形縮框
  6 const double eps = 1e-12// 計算精度
  7 
  8 struct Point {
  9     double x, y;
 10 };
 11 
 12 struct Line {
 13     Point a, b;
 14     bool flag;
 15 };
 16 
 17 inline int dcmp(double x) {
 18     return x < -eps ? -1 : x > eps;
 19 }
 20 
 21 inline bool LEQ(double x, double y) // less equal, x <= y
 22 {
 23     return dcmp(x - y) <= 0;
 24 }
 25 
 26 inline bool GEQ(double x, double y) // greater equal, x >= y
 27 {
 28     return dcmp(x - y) >= 0;
 29 }
 30 
 31 double xmult(Point p1, Point p2, Point p0)//p0是原點
 32 {
 33     return (p1.x - p0.x)*(p2.y - p0.y)-(p2.x - p0.x)*(p1.y - p0.y);
 34 }
 35 
 36 vector<Line> stack;
 37 Point poly[4];
 38 int n;
 39 
 40 Point SymPoint(Point p, Line L) // 求二維平面上點p關于直線L的對稱點
 41 {
 42     Point result;
 43     double a = L.b.x - L.a.x;
 44     double b = L.b.y - L.a.y;
 45     double t = ((p.x - L.a.x) * a + (p.y - L.a.y) * b) / (a * a + b * b);
 46     result.x = 2 * L.a.x + 2 * a * t - p.x;
 47     result.y = 2 * L.a.y + 2 * b * t - p.y;
 48     return result;
 49 }
 50 
 51 Line SymLine(Line L, Line base) {
 52     L.a = SymPoint(L.a, base);
 53     L.b = SymPoint(L.b, base);
 54     return L;
 55 }
 56 
 57 bool segcross(Line L1, Line L2) // 判斷二維的兩條線段是否相交
 58 {
 59     return (GEQ(max(L1.a.x, L1.b.x), min(L2.a.x, L2.b.x)) &&
 60             GEQ(max(L2.a.x, L2.b.x), min(L1.a.x, L1.b.x)) &&
 61             GEQ(max(L1.a.y, L1.b.y), min(L2.a.y, L2.b.y)) &&
 62             GEQ(max(L2.a.y, L2.b.y), min(L1.a.y, L1.b.y)) &&
 63             LEQ(xmult(L2.a, L1.b, L1.a) * xmult(L2.b, L1.b, L1.a), 0&&
 64             LEQ(xmult(L1.a, L2.b, L2.a) * xmult(L1.b, L2.b, L2.a), 0));
 65 }
 66 
 67 bool inside_convex(Point q) {
 68     for (int i = 0; i < 4; i++)
 69         if (dcmp(xmult(poly[(i + 1% 4], q, poly[i])) < 0)return false;
 70     return true;
 71 }
 72 
 73 bool in_poly(Line fold) {
 74     Line L;
 75     if (inside_convex(fold.a))return true;
 76     for (int i = 0; i < 4; i++) {
 77         L.a = poly[i];
 78         L.b = poly[(i + 1% 4];
 79         if (segcross(fold, L)) return true;
 80     }
 81     return false;
 82 }
 83 
 84 void construt_poly(Line L1, Line L2) {
 85     poly[0].x = L1.a.x + EPS;
 86     poly[0].y = L1.a.y + EPS;
 87     poly[1].x = L2.a.x - EPS;
 88     poly[1].y = L2.a.y + EPS;
 89     poly[2].x = L2.b.x - EPS;
 90     poly[2].y = L2.b.y - EPS;
 91     poly[3].x = L1.b.x + EPS;
 92     poly[3].y = L1.b.y - EPS;
 93 }
 94 
 95 bool isBad(Line fold) {
 96     int cnt = stack.size();
 97     if (cnt < 2 || fold.flag != stack[cnt - 1].flag)return false;
 98     while (cnt >= 2) {
 99         fold = SymLine(fold, stack[cnt - 1]);
100         construt_poly(stack[cnt - 2], stack[cnt - 1]);
101         if (in_poly(fold))return true;
102         cnt--;
103     }
104     return false;
105 }
106 
107 int main() {
108     //freopen("in","r",stdin);
109     Line left;
110     left.a.x = left.b.x = 0;
111     left.a.y = 0, left.b.y = 1;
112     while (scanf("%d"&n) != EOF && n) {
113         stack.clear();
114         stack.push_back(left);
115         bool good = true;
116         for (int i = 0; i < n; i++) {
117             Line tem;
118             tem.b.y = 1;
119             tem.a.y = 0;
120             scanf("%lf %lf %d"&tem.b.x, &tem.a.x, &tem.flag);
121             if (good) {
122                 if (isBad(tem)) {
123                     printf("NO %d\n", i + 1);
124                     good = false;
125                     continue;
126                 }
127                 stack.push_back(tem);
128             }
129         }
130         if (good) printf("YES\n");
131     }
132 }


posted on 2009-09-30 16:27 wangzhihao 閱讀(373) 評論(0)  編輯 收藏 引用 所屬分類: 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>
            欧美精品在线免费| 欧美激情亚洲综合一区| 国产日韩欧美另类| 久久成人综合网| 久久精品色图| 亚洲欧洲另类国产综合| 亚洲欧洲在线视频| 欧美日韩美女一区二区| 校园激情久久| 久久久最新网址| 夜夜躁日日躁狠狠久久88av| 正在播放日韩| 红杏aⅴ成人免费视频| 欧美黑人在线播放| 国产精品扒开腿做爽爽爽软件| 欧美在线播放一区| 免费观看30秒视频久久| 亚洲一区二区三区精品动漫| 午夜亚洲伦理| 日韩天堂av| 欧美一区二区三区四区在线观看地址 | 亚洲国产精品成人久久综合一区| 欧美日韩国产123区| 欧美在线一二三四区| 欧美成年人网| 欧美主播一区二区三区美女 久久精品人| 欧美影院精品一区| 中国日韩欧美久久久久久久久| 先锋a资源在线看亚洲| 亚洲人成网站精品片在线观看| 亚洲综合色视频| 亚洲精品一二三区| 久久国产欧美| 欧美一区二区三区免费观看| 欧美黄色网络| 久久躁狠狠躁夜夜爽| 国产精品乱人伦一区二区| 亚洲福利国产| 伊人男人综合视频网| 亚洲一区免费| 亚洲一区二区免费| 欧美激情第3页| 久久综合综合久久综合| 欧美视频亚洲视频| 亚洲区国产区| 亚洲精品一级| 牛牛精品成人免费视频| 久热国产精品视频| 国产一区二区三区四区hd| 中国成人亚色综合网站| 中文精品视频| 欧美日本在线| 亚洲激情欧美激情| 亚洲欧洲三级| 欧美暴力喷水在线| 欧美黄色影院| 亚洲激情午夜| 欧美成人国产va精品日本一级| 久久综合色婷婷| 国产在线一区二区三区四区 | 亚洲性xxxx| 亚洲一区二区成人| 欧美视频网址| 亚洲一区二区三区中文字幕在线 | 亚洲清纯自拍| 欧美成人综合一区| 亚洲国产成人av好男人在线观看| 最新亚洲视频| 欧美精品激情blacked18| 亚洲人成网站在线播| 日韩午夜一区| 欧美视频中文一区二区三区在线观看| 亚洲另类春色国产| 亚洲综合激情| 国产一区视频在线观看免费| 久久成人精品无人区| 蜜臀久久久99精品久久久久久| 在线精品国产欧美| 牛牛精品成人免费视频| 亚洲人成久久| 亚洲欧美日韩在线高清直播| 国产欧美在线| 久久深夜福利免费观看| 亚洲国产日韩在线| 亚洲欧美国产精品桃花| 国产视频一区在线观看| 老司机免费视频一区二区| 最新69国产成人精品视频免费| 一区二区三区国产盗摄| 国产乱码精品| 美日韩丰满少妇在线观看| 亚洲精品国精品久久99热一| 午夜亚洲福利在线老司机| 激情六月婷婷综合| 欧美日韩国产色站一区二区三区| 亚洲免费视频观看| 欧美高清视频一区二区| 亚洲摸下面视频| 亚洲国产网站| 国产精品一区免费视频| 蜜臀a∨国产成人精品| 亚洲一二三区精品| 欧美激情免费观看| 欧美伊人久久| 一区二区三区免费看| 狠狠狠色丁香婷婷综合久久五月| 欧美肥婆bbw| 久久成人精品无人区| 日韩一级黄色av| 免费日韩av片| 久久国产毛片| 亚洲午夜精品| 亚洲国产一区视频| 国产一区二区三区四区老人| 欧美日韩伦理在线免费| 久久天天躁狠狠躁夜夜爽蜜月 | 久久久久久久久久码影片| 日韩一区二区免费高清| 亚洲福利视频一区| 国产日本欧美一区二区三区在线 | 久久精品国产99国产精品| 一本色道久久综合亚洲91| 欧美激情一区二区三区不卡| 久久精品国产久精国产爱| 亚洲一区二区三区四区视频| 在线看片欧美| 韩日在线一区| 国产专区综合网| 国产午夜精品麻豆| 国产精品日韩精品欧美在线 | 可以看av的网站久久看| 久久精品99国产精品日本| 亚洲欧美日韩国产综合| 在线亚洲欧美| 亚洲天堂视频在线观看| 亚洲全黄一级网站| 亚洲精品乱码久久久久久按摩观 | 亚洲欧美日韩视频二区| 夜夜躁日日躁狠狠久久88av| 亚洲精品乱码| 亚洲精品国久久99热| 亚洲国产精品久久久久秋霞不卡 | 国产精品极品美女粉嫩高清在线| 欧美另类在线播放| 欧美精品xxxxbbbb| 欧美日韩国产综合在线| 欧美日韩中文| 国产精品中文字幕在线观看| 国产精品亚洲综合色区韩国| 国产伦精品免费视频| 国产亚洲午夜| 一区二区三区在线免费视频| 在线观看日韩欧美| 亚洲另类视频| 亚洲一级在线| 久久久91精品国产| 免费人成精品欧美精品| 亚洲国产日韩欧美在线99| 亚洲毛片在线观看| 午夜精品久久久久久久蜜桃app| 午夜一级久久| 另类综合日韩欧美亚洲| 欧美精品免费在线| 国产精品天美传媒入口| 黑人一区二区三区四区五区| 亚洲人成久久| 欧美一区日本一区韩国一区| 老司机精品福利视频| 亚洲激情在线激情| 午夜精品久久久久久久99水蜜桃| 久久精品99国产精品| 欧美精品一区二区三区蜜桃| 国产精品专区第二| 亚洲国产精品美女| 香港成人在线视频| 欧美高清在线一区| 亚洲一区二区综合| 另类欧美日韩国产在线| 国产精品露脸自拍| 亚洲国产日韩欧美在线动漫| 亚洲伊人色欲综合网| 老司机午夜精品视频| 一区二区三区精品视频| 久久久亚洲一区| 国产精品入口夜色视频大尺度| 亚洲国产精品va在线看黑人| 午夜精品久久久久久久久久久| 免费在线成人av| 亚洲欧美成人| 欧美日韩国产欧| 亚洲福利一区| 久久久精品一品道一区| 夜夜嗨av一区二区三区免费区| 久久综合给合久久狠狠色| 国产精品美女在线| 一区二区日韩免费看| 欧美激情bt| 久久久久国色av免费观看性色| 国产精品永久在线| 亚洲一区www|