• <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++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::

            《編程之美》讀書筆記144.4 是否在三角形內(nèi)

             

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



            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內(nèi)
              if (t==1 || t==4)  return true;  //與點(diǎn)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;  

              
            //在三角形內(nèi)a[3]=a[12]=1 在邊上 a[2]=a[8]=1 在頂點(diǎn)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日韩AV永久无码久久| 成人免费网站久久久| 久久这里只有精品首页| 国产精品久久久久国产A级| 亚洲国产精品无码久久久蜜芽| 亚洲欧美成人久久综合中文网| 亚洲日本va午夜中文字幕久久| 伊人久久大香线蕉AV一区二区| 色婷婷狠狠久久综合五月| 日韩亚洲国产综合久久久| 国产一区二区久久久| 久久综合给合久久狠狠狠97色| 久久精品国产亚洲av高清漫画| 青青青青久久精品国产| 中文字幕无码av激情不卡久久| 久久婷婷五月综合色奶水99啪| 蜜臀久久99精品久久久久久小说 | 久久夜色精品国产欧美乱| 2022年国产精品久久久久| 久久精品免费网站网| 国产69精品久久久久久人妻精品| 久久香蕉综合色一综合色88| 一级做a爰片久久毛片人呢| 亚洲国产精品久久| 77777亚洲午夜久久多人| 久久久久久久久无码精品亚洲日韩| 久久中文字幕一区二区| 亚洲v国产v天堂a无码久久| 97久久婷婷五月综合色d啪蜜芽| 国内精品久久九九国产精品| 日本福利片国产午夜久久| 国产亚洲精品久久久久秋霞| 国产99久久精品一区二区| 亚洲国产成人精品女人久久久 | 国产麻豆精品久久一二三| 久久久久国产| 久久无码人妻精品一区二区三区| 东京热TOKYO综合久久精品| 亚洲人成无码网站久久99热国产| 天天久久狠狠色综合| 成人资源影音先锋久久资源网|