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

            QuXiao

            每天進(jìn)步一點(diǎn)點(diǎn)!

              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              50 隨筆 :: 0 文章 :: 27 評(píng)論 :: 0 Trackbacks

            一道幾何題,解決方法很容易想到,不過要細(xì)心。

            隨著輸入的順序,將矩形一個(gè)個(gè)放入集合,如果新的矩形與集合中的舊矩形相交,就將舊矩形分解,刪除舊矩形,放入新矩形和分解的矩形。

            設(shè)矩形R1、R2,寬和高分別為(W1, H1)和(W2, H2),兩矩形中心坐標(biāo)分別為(X1, Y1)以及(X2, Y2)。判斷兩矩形是否相交(也就是是否有面積相重合),就看兩矩形中心坐標(biāo)的豎直和水平距離是否小于兩矩形高的和的一半以及兩矩形寬的和的一半。即:

            ( |X1 - X2| < (W1 + W2) / 2 ) && ( |Y1 - Y2| < (H1 + H2) / 2 )

            如果條件滿足,R1和R2即相交。

            那相交會(huì)有幾種情況呢?我想到了16種:

            image

            根據(jù)不同的情況,可以將原來的矩形分解為0~4個(gè)小矩形,這樣就可以解出來了。

            (做幾何題可真費(fèi)草稿紙啊,看來以后得學(xué)學(xué)matlab了,低碳、環(huán)保!)

            另外,USACO還有一種解法,就是將矩形的四條邊進(jìn)行離散化處理,將線段排序,然后再依次掃描,大體思路是這樣的,具體細(xì)節(jié)沒怎么看。

            posted on 2011-02-01 20:55 quxiao 閱讀(204) 評(píng)論(0)  編輯 收藏 引用

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


            久久久久一级精品亚洲国产成人综合AV区 | 国产精品免费福利久久| 久久综合久久自在自线精品自 | 国产V综合V亚洲欧美久久| 久久精品国产福利国产秒| 亚洲国产成人久久精品影视| 亚洲成色999久久网站| 国产精品久久久久免费a∨| 日产精品99久久久久久| 久久一区二区免费播放| 久久精品国产亚洲AV麻豆网站| 99热精品久久只有精品| 久久久久国产精品人妻 | 伊人久久大香线蕉AV一区二区| 免费无码国产欧美久久18| 94久久国产乱子伦精品免费| 久久这里只有精品首页| 国产精品无码久久四虎| 91久久精一区二区三区大全| 少妇久久久久久被弄到高潮| 99国产欧美久久久精品蜜芽| 亚洲AⅤ优女AV综合久久久| 青青草原1769久久免费播放| 久久这里只有精品18| 97视频久久久| 理论片午午伦夜理片久久| 久久se精品一区二区| 奇米综合四色77777久久| 精品久久久久久久久免费影院| 精品久久久久久无码中文字幕| 久久国产精品无码HDAV| 久久久噜噜噜久久熟女AA片| 久久精品国产免费观看| 蜜桃麻豆WWW久久囤产精品| 午夜精品久久久内射近拍高清| 国产999精品久久久久久| 久久亚洲国产中v天仙www| 久久精品国产只有精品2020| 久久久久久久99精品免费观看| 97热久久免费频精品99| 久久精品国产免费一区|