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

            雁過無痕

              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::

            《編程之美》讀書筆記144.4 是否在三角形內

             

                對幾何題目,常用到矢量。若P點在三角形內部,則矢量PA沿時鐘某個方向三次旋轉分別經過PB、PC再回到PA,每次旋轉角度都不會超過180度。即PA×PB、PB×PC和PC×PA這三個矢量積應該都為正,或都為負。如果P在三角形邊上,則這三個矢量積應該一個為0,其它兩個同正或同負。若在三角形某個頂點,則三個矢量積,必有兩個為0,一個不為0。若A B C三點共線,P在這直線上,則所有矢量積均為0,若P不在這直線上,則為兩正一負或兩負一正。



            struct Point{
              
            double x;
              
            double y;
            }
            ;

            static int direction(const Point& a, const Point& b, const Point& p)
            {
              
            const double zero=1e-6;
              
            double tmp=(p.x-a.x)*(p.y-b.y)-(p.x-b.x)*(p.y-a.y);
              
            if (tmp > zero) return 1;
              
            if (tmp < -1*zero) return 4;
              
            return 0;
            }


            bool is_in_triangle(const Point& a, const Point& b, const Point& c, const Point& p)
            {
              
            int t= direction(a,b,p)+ direction(b,c,p) + direction(c,a,p);
              
            /*
              if (t==3 || t==12) return true;   //在三角形ABC內
              if (t==1 || t==4)  return true;  //與點A B C之一重合
              if (t==2 || t==8)  return true;  //在三角形ABC邊上。
              
            */

              
            if (t>=1 && t<=4return true;
              
            if (t==8 || t==12return true;
              
            return false;  

              
            //在三角形內a[3]=a[12]=1 在邊上 a[2]=a[8]=1 在頂點a[1]=a[4]=1;
              
            //int a[]={0, 1,1,1,1, 0,0,0, 1, 0,0,0, 1};
              
            //return a[direction(a,b,p)+direction(b,c,p)+direction(c,a,p)];  
            }


            posted on 2010-08-16 00:34 flyinghearts 閱讀(831) 評論(0)  編輯 收藏 引用 所屬分類: 編程之美
            欧洲人妻丰满av无码久久不卡 | 久久亚洲精品人成综合网| 久久久久亚洲?V成人无码| 免费一级做a爰片久久毛片潮| 亚洲国产精品综合久久一线| 国内精品久久久久影院亚洲| 久久婷婷五月综合97色| 青青草原综合久久| 午夜视频久久久久一区| 亚洲中文字幕无码久久2017| 久久91精品国产91久久户| 久久播电影网| 久久久久人妻精品一区 | 精品伊人久久大线蕉色首页| 久久er99热精品一区二区| 欧美麻豆久久久久久中文| 久久夜色精品国产噜噜麻豆| 99久久国产综合精品网成人影院| 亚洲精品午夜国产va久久| 国产精品久久影院| 日产精品久久久久久久性色| 久久久精品国产Sm最大网站| www.久久热.com| 久久久久久久精品成人热色戒 | 久久99精品国产一区二区三区 | 66精品综合久久久久久久| 久久夜色精品国产亚洲| 久久精品无码一区二区三区日韩| AV无码久久久久不卡蜜桃| 一本一本久久aa综合精品| 狠狠色丁香久久婷婷综合_中| 久久青青草原精品国产不卡| 久久亚洲国产欧洲精品一| 精品国产VA久久久久久久冰| 亚洲国产精品无码久久久蜜芽 | 久久亚洲精品无码观看不卡| 一本大道加勒比久久综合| 久久久久久a亚洲欧洲aⅴ| 久久九九亚洲精品| 伊人久久综在合线亚洲2019 | 久久国产亚洲精品|