• <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>

            ZOJ 1081 Points Within

            Points Within

            Time limit: 1 Seconds   Memory limit: 32768K  
            Total Submit: 2222   Accepted Submit: 566  

            Statement of the Problem

            Several drawing applications allow us to draw polygons and almost all of them allow us to fill them with some color. The task of filling a polygon reduces to knowing which points are inside it, so programmers have to colour only those points.

            You're expected to write a program which tells us if a given point lies inside a given polygon described by the coordinates of its vertices. You can assume that if a point is in the border of the polygon, then it is in fact inside the polygon.

            Input Format

            The input file may contain several instances of the problem. Each instance consists of: (i) one line containing integers N, 0 < N < 100 and M, respectively the number of vertices of the polygon and the number of points to be tested. (ii) N lines, each containing a pair of integers describing the coordinates of the polygon's vertices; (iii) M lines, each containing a pair of integer coordinates of the points which will be tested for "withinness" in the polygon.

            You may assume that: the vertices are all distinct; consecutive vertices in the input are adjacent in the polygon; the last vertex is adjacent to the first one; and the resulting polygon is simple, that is, every vertex is incident with exactly two edges and two edges only intersect at their common endpoint. The last instance is followed by a line with a 0 (zero).

            Output Format

            For the ith instance in the input, you have to write one line in the output with the phrase "Problem i:", followed by several lines, one for each point tested, in the order they appear in the input. Each of these lines should read "Within" or "Outside", depending on the outcome of the test. The output of two consecutive instances should be separated by a blank line.

            Sample Input

            3 1
            0 0
            0 5
            5 0
            10 2
            3 2
            4 4
            3 1
            1 2
            1 3
            2 2
            0

            Sample Output

            Problem 1:
            Outside

            Problem 2:
            Outside
            Within


            Problem Source: South America 2001
            Analysis
            Algorithm:
            This problem is simple to understand. In order to determine the given point whether it is inner, initially, we should exclude the situation of the online occurrence. Be careful of the points which is an component of the polygon. And later, draw a directed line randomly and count the crossing points. If it is even, it is obviously inner and true for another situation: the point is outside when the result is odd.

            code
             
            #include <iostream>   
            using namespace std;   
            struct point{   
                
            int x, y;   
            }
            ;   
            struct line{   
                point p1, p2;   
            }
            ;   
            const int MAXN = 101;   
            const int MAX = 99999999;   
            point p[MAXN];   
            int m, n;   
            inline 
            int max(line l){   
                
            return (l.p1.y > l.p2.y ? l.p1.y : l.p2.y);   
            }
               
            inline 
            int min(line l){   
                
            return (l.p1.y > l.p2.y ? l.p2.y : l.p1.y);   
            }
               
            inline 
            int xmult(int x1, int y1, int x2, int y2){   
                
            return x1 * y2 - x2 * y1;   
            }
               
            inline 
            int pmult(int x1, int y1, int x2, int y2){   
                
            return x1 * x2 + y1 * y2;   
            }
               
            inline 
            int cmp(int x){   
                
            if (x == 0return 0;   
                
            if (x < 0return -1;   
                
            if (x > 0return 1;   
            }
               
            inline 
            int cross(point a, point b, point c){   
                
            return cmp(xmult(b.x - a.x, b.y - a.y, c.x - a.x, c.y - a.y));   
            }
               
            inline 
            int linecross(line l1, line l2){   
                
            return (cross(l1.p1, l2.p1, l2.p2) * cross(l1.p2, l2.p1, l2.p2) < 0   
                    
            && cross(l2.p1, l1.p1, l1.p2) * cross(l2.p2, l1.p1, l1.p2) < 0);   
            }
               
            int test(point tp){   
                line poly, t;   
                
            int x = 0;   
                t.p1 
            = tp; t.p2.x = 1280213; t.p2.y = 321123;   
                
            for (int i = 0; i != n; ++i){   
                    
            if (i == n - 1){   
                        poly.p1 
            = p[n - 1]; poly.p2 = p[0];   
                    }
             else {   
                        poly.p1 
            = p[i]; poly.p2 = p[i + 1];   
                    }
               
                    
            while(online(poly.p1,t.p1,t.p2)||online(poly.p2,t.p1,t.p2)) {t.p2.x++;t.p2.y++;}
                    
            if (linecross(poly, t)) ++x;   
                }
               
                
            if (x % 2return 1else return 0;   
            }
               
              
            int online(point tp, point a, point b){   
                
            if (cmp(xmult(tp.x - a.x, tp.y - a.y, b.x - a.x, b.y - a.y)) == 0 &&   
                    cmp(pmult(tp.x 
            - a.x, tp.y - a.y, tp.x - b.x, tp.y - b.y)) < 0 ) return 1else return 0;   
            }
               
            int checkonline(point tp){   
                
            for (int i = 0; i != n; ++i){   
                    
            if (tp.x == p[i].x && tp.y == p[i].y) return 1;   
                }
               
                
            for (int i = 0; i != n - 1++i){   
                    
            if (online(tp, p[i], p[i + 1])) return 1;   
                }
               
                
            if (online(tp, p[n - 1], p[0])) return 1else return 0;   
            }
               
            int main(){   
                
            int cases = 0;   
                point tp;   
                
            while (cin >> n && n != 0){   
                    cin 
            >> m;   
                    
            ++cases;   
                    
            if (cases != 1) cout << endl;   
                    
            for (int i = 0; i != n; ++i) cin >> p[i].x >> p[i].y;   
                    cout 
            << "Problem " << cases << ":" << endl;   
                    
            for (int i = 0; i != m; ++i){   
                        cin 
            >> tp.x >> tp.y;   
                        
            if (checkonline(tp)){   
                            cout 
            << "Within" << endl;   
                            
            continue;   
                        }
               
                        
            if (test(tp)) cout << "Within" << endl; else cout << "Outside" << endl;   
                    }
               
                }
               
                
            return 0;   
            }
              

            posted on 2008-08-09 21:02 幻浪天空領(lǐng)主 閱讀(452) 評論(0)  編輯 收藏 引用 所屬分類: ZOJ


            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            <2025年8月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            導(dǎo)航

            統(tǒng)計

            常用鏈接

            留言簿(1)

            隨筆檔案(2)

            文章分類(23)

            文章檔案(22)

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            久久91精品国产91久久小草| 国产精品欧美久久久久无广告| 久久婷婷国产剧情内射白浆| 久久婷婷五月综合97色一本一本| 久久成人精品视频| 日本久久中文字幕| 色偷偷888欧美精品久久久| 久久综合久久伊人| 99久久婷婷免费国产综合精品| 国产视频久久| 国产三级久久久精品麻豆三级| 久久性精品| 精品国产91久久久久久久a| 久久久久久久波多野结衣高潮| 国产免费久久精品99久久| 久久久久久毛片免费播放| 久久久SS麻豆欧美国产日韩| 国产精品久久久久9999| 亚洲AV无一区二区三区久久| 青青草原综合久久大伊人| 精品久久久久中文字幕一区| 久久精品国产91久久综合麻豆自制| 欧美伊人久久大香线蕉综合| 久久亚洲高清综合| 久久精品成人影院| 久久久人妻精品无码一区| 国产综合成人久久大片91| 97久久天天综合色天天综合色hd| 亚洲欧洲日产国码无码久久99| 日韩电影久久久被窝网| 亚洲欧美精品一区久久中文字幕| 久久久久久久国产免费看| 麻豆国内精品久久久久久| 久久精品国产色蜜蜜麻豆| 久久久久亚洲精品中文字幕| 伊人伊成久久人综合网777| 亚洲а∨天堂久久精品9966| 久久人人爽人人人人片av| 国产精品中文久久久久久久| 91麻豆国产精品91久久久| 久久妇女高潮几次MBA|