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

            pku 1266 ural 1043 Cover an Arc. 解析幾何,注意浮點(diǎn)數(shù)下取整要用floor函數(shù)

            題意:
            給出一段圓弧的起點(diǎn)、終點(diǎn)以及第三點(diǎn)(三點(diǎn)不共線),求4個(gè)點(diǎn)在整點(diǎn)的最小矩形將其圍住。

            測(cè)試數(shù)據(jù):
            /Files/yzhw/cover.rar

            解法:
            首先,肯定要求圓心的
            大家數(shù)學(xué)都很牛,我就給一個(gè)圖,一個(gè)式子,你懂的

            CE2=DB2+DE2
            然后用解析法做吧- -,要討論下A、B是否為水平線或者豎直線

            下面就是確定上下左右整點(diǎn)坐標(biāo)的問題了
            還記得math庫(kù)里有atan2?嘻嘻,那就好辦了
            要分兩種情況討論,

            A、B是弧的端點(diǎn)。
            也許這兩種情況從幾何上看MS一樣的,但是對(duì)于求atan2就不同了
            大家知道,atan2返回值是-PI~PI
            也就是說,(-1,0)向量返回PI,(1,0)返回0,然后(-1,0)向逆時(shí)針方向轉(zhuǎn)一點(diǎn)點(diǎn)就是返回接近-PI的數(shù)了,-PI和PI是同一點(diǎn),但atan2處理的時(shí)候PI位置是閉區(qū)間,而-PI位置是開區(qū)間。
            廢話了一堆,大家應(yīng)該明白了,上圖第一種情況C的atan2值是大于a、b的最大值或者小于a、b的最小值的,而第二種情況d的atan2值是介于e、f之間的。
            分類討論,然后分別測(cè)試-PI向量、PI/2向量、0向量、-PI/2向量是否在圓弧內(nèi)就可以了。
            一個(gè)值得注意的地方,下取整應(yīng)該使用floor函數(shù),應(yīng)為如果直接int取整,當(dāng)浮點(diǎn)值小于0的時(shí)候就變成上取整了- -
            我感覺自己的代碼寫的很到位的,再有不懂得大家看我代碼吧,不過話說java的效率真蛋疼。。一個(gè)O(1)的算法竟然能跑5秒。。。

            代碼:
              1Source Code
              2
              3Problem: 1266  User: yzhw 
              4Memory: 3024K  Time: 5422MS 
              5Language: Java  Result: Accepted 
              6
              7Source Code 
              8import java.util.*;
              9public class Main {
             10
             11    /**
             12     * @param args
             13     */

             14    static int x1,x2,x3,y1,y2,y3,left,right,up,down;
             15    static double x,y,x4,y4,d,r;
             16    static double dis(double x1,double y1,double x2,double y2)
             17    {
             18        return Math.sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2));
             19    }

             20    static double cross(double x1,double y1,double x2,double y2)
             21    {
             22        return x1*y2-x2*y1;
             23    }

             24    static boolean gt(double num,double pos)
             25    {
             26        return Math.abs(num-pos)<1e-6||num>pos;
             27    }

             28    static boolean le(double num,double pos)
             29    {
             30        return Math.abs(num-pos)<1e-6||num<pos;
             31    }

             32    static int floor(double num)
             33    {
             34        num+=1e-8;
             35        int res=(int)Math.floor(num);
             36        if(Math.abs(res-num)<1e-6return res;
             37        else return res+1;
             38    }

             39    public static void main(String[] args) {
             40        Scanner in=new Scanner (System.in);
             41        x1=in.nextInt();
             42        y1=in.nextInt();
             43        x2=in.nextInt();
             44        y2=in.nextInt();
             45        x3=in.nextInt();
             46        y3=in.nextInt();
             47        x4=(x1+x2)*0.5;
             48        y4=(y1+y2)*0.5;
             49        d=dis(x1,y1,x4,y4);
             50        if(x1==x2)
             51        {
             52            y=(y1+y2)*0.5;
             53            x=(d*d+x4*x4+y4*y4-x3*x3-y3*y3-y*2.0*(y4-y3))*0.5/(x4-x3);
             54        }

             55        else if(y1==y2)
             56        {
             57            x=(x1+x2)*0.5;
             58            y=(d*d+x4*x4+y4*y4-x3*x3-y3*y3-x*2.0*(x4-x3))*0.5/(y4-y3);
             59        }

             60        else
             61        {
             62            double k=(x1-x2)/(double)(y2-y1);
             63            double t=d*d+x4*x4+y4*y4-x3*x3-y3*y3-2.0*(y4-y3)*(y4-k*x4);
             64            x=t/(2.0*(x4-x3)+2.0*(y4-y3)*k);
             65            y=k*x+y4-k*x4;
             66        }

             67        r=dis(x3,y3,x,y);
             68        //System.out.println(x+" "+y+" "+r);
             69        double start=Math.atan2(y1-y, x1-x),end=Math.atan2(y2-y, x2-x),nxt=Math.atan2(y3-y,x3-x);
             70        if(le(nxt,Math.min(start,end))||gt(nxt,Math.max(start,end)))
             71        {
             72            if(le(Math.PI,Math.min(start,end))||gt(Math.PI,Math.max(start,end)))
             73               left=(int)Math.floor(x-r+1e-8);
             74            else
             75                left=Math.min(x1, x2);
             76            if(le(0,Math.min(start,end))||gt(0,Math.max(start,end)))
             77                   right=floor(x+r);
             78                else
             79                   right=Math.max(x1, x2);
             80            if(le(-Math.PI*0.5,Math.min(start,end))||gt(-Math.PI*0.5,Math.max(start,end)))
             81                   down=(int)Math.floor(y-r+1e-8);
             82                else
             83                   down=Math.min(y1, y2);
             84            if(le(Math.PI*0.5,Math.min(start,end))||gt(Math.PI*0.5,Math.max(start,end)))
             85                   up=floor(y+r);
             86                else
             87                   up=Math.max(y1, y2);
             88        }

             89        else
             90        {
             91            if(le(Math.PI,Math.max(start,end))&&gt(Math.PI,Math.min(start,end)))
             92                   left=(int)Math.floor(x-r+1e-8);
             93                else
             94                    left=Math.min(x1, x2);
             95            if(le(0,Math.max(start,end))&&gt(0,Math.min(start,end)))
             96                       right=floor(x+r);
             97                    else
             98                       right=Math.max(x1, x2);
             99            if(le(-Math.PI*0.5,Math.max(start,end))&&gt(-Math.PI*0.5,Math.min(start,end)))
            100                       down=(int)Math.floor(y-r+1e-8);
            101                    else
            102                       down=Math.min(y1, y2);
            103            if(le(Math.PI*0.5,Math.max(start,end))&&gt(Math.PI*0.5,Math.min(start,end)))
            104                       up=floor(y+r);
            105                    else
            106                       up=Math.max(y1, y2);
            107        }

            108        System.out.println((right-left)*(up-down));
            109    }

            110
            111}

            112
            113

            posted on 2011-01-18 10:44 yzhw 閱讀(605) 評(píng)論(0)  編輯 收藏 引用 所屬分類: geometry&phycise

            <2011年1月>
            2627282930311
            2345678
            9101112131415
            16171819202122
            23242526272829
            303112345

            導(dǎo)航

            統(tǒng)計(jì)

            公告

            統(tǒng)計(jì)系統(tǒng)

            留言簿(1)

            隨筆分類(227)

            文章分類(2)

            OJ

            最新隨筆

            搜索

            積分與排名

            最新評(píng)論

            閱讀排行榜

            狠狠干狠狠久久| 色噜噜狠狠先锋影音久久| 久久精品成人欧美大片| 国产精品久久久久久| 久久不射电影网| 久久久亚洲欧洲日产国码二区| 国内精品久久国产大陆| 伊人久久大香线焦AV综合影院 | 国产精品久久99| 日产精品久久久久久久| 久久久久久狠狠丁香| 久久香蕉国产线看观看精品yw | 久久综合给合久久国产免费| 老男人久久青草av高清| 国内精品久久久久伊人av| 国产精品日韩欧美久久综合| 亚洲精品午夜国产va久久| 日日噜噜夜夜狠狠久久丁香五月| 综合网日日天干夜夜久久| 精品多毛少妇人妻AV免费久久| 97久久精品国产精品青草| 精品无码久久久久久午夜| 国产精品久久自在自线观看| 久久精品人人做人人爽电影| 国产午夜电影久久| 婷婷久久综合| 日本道色综合久久影院| 国产成人精品久久亚洲高清不卡 | 久久国产香蕉一区精品| 亚洲国产天堂久久久久久| 成人a毛片久久免费播放| 久久免费大片| 久久婷婷综合中文字幕| 久久久久人妻一区精品果冻| 狠狠综合久久综合88亚洲| 久久er99热精品一区二区| 久久WWW免费人成—看片| 狠狠久久亚洲欧美专区| 久久影院久久香蕉国产线看观看| 久久久久免费精品国产| 中文字幕成人精品久久不卡|