一道幾何題,解決方法很容易想到,不過要細(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種:
根據(jù)不同的情況,可以將原來的矩形分解為0~4個(gè)小矩形,這樣就可以解出來了。
(做幾何題可真費(fèi)草稿紙啊,看來以后得學(xué)學(xué)matlab了,低碳、環(huán)保!)
另外,USACO還有一種解法,就是將矩形的四條邊進(jìn)行離散化處理,將線段排序,然后再依次掃描,大體思路是這樣的,具體細(xì)節(jié)沒怎么看。