原文地址:http://www.javashuo.com/article/p-ohzinrjn-bo.html html
Given N axis-aligned rectangles where N > 0, determine if they all together form an exact cover of a rectangular region.spa
Each rectangle is represented as a bottom-left point and a top-right point. For example, a unit square is represented as [1,1,2,2]. (coordinate of bottom-left point is (1, 1) and top-right point is (2, 2)).code
Example 1:orm
rectangles = [ [1,1,3,3], [3,1,4,2], [3,2,4,4], [1,3,2,4], [2,3,3,4] ] Return true. All 5 rectangles together form an exact cover of a rectangular region.
Example 2:htm
rectangles = [ [1,1,2,3], [1,3,2,4], [3,1,4,2], [3,2,4,4] ] Return false. Because there is a gap between the two rectangular regions.
Example 3:blog
rectangles = [ [1,1,3,3], [3,1,4,2], [1,3,2,4], [3,2,4,4] ] Return false. Because there is a gap in the top center.
Example 4:rem
rectangles = [ [1,1,3,3], [3,1,4,2], [1,3,2,4], [2,2,4,4] ] Return false. Because two of the rectangles overlap with each other.
咱們有 N 個與座標軸對齊的矩形, 其中 N > 0, 判斷它們是否能精確地覆蓋一個矩形區域。get
每一個矩形用左下角的點和右上角的點的座標來表示。例如, 一個單位正方形能夠表示爲 [1,1,2,2]。 ( 左下角的點的座標爲 (1, 1) 以及右上角的點的座標爲 (2, 2) )。it
示例 1:io
rectangles = [ [1,1,3,3], [3,1,4,2], [3,2,4,4], [1,3,2,4], [2,3,3,4] ] 返回 true。5個矩形一塊兒能夠精確地覆蓋一個矩形區域。
示例 2:
rectangles = [ [1,1,2,3], [1,3,2,4], [3,1,4,2], [3,2,4,4] ] 返回 false。兩個矩形之間有間隔,沒法覆蓋成一個矩形。
示例 3:
rectangles = [ [1,1,3,3], [3,1,4,2], [1,3,2,4], [3,2,4,4] ] 返回 false。圖形頂端留有間隔,沒法覆蓋成一個矩形。
示例 4:
rectangles = [ [1,1,3,3], [3,1,4,2], [1,3,2,4], [2,2,4,4] ] 返回 false。由於中間有相交區域,雖然造成了矩形,但不是精確覆蓋。
524ms
1 class Solution { 2 func isRectangleCover(_ rectangles: [[Int]]) -> Bool { 3 var st:Set<String> = Set<String>() 4 var min_x = Int.max 5 var min_y = Int.max 6 var max_x = Int.min 7 var max_y = Int.min 8 var area:Int = 0 9 for rect in rectangles 10 { 11 min_x = min(min_x, rect[0]) 12 min_y = min(min_y, rect[1]) 13 max_x = max(max_x, rect[2]) 14 max_y = max(max_y, rect[3]) 15 area += (rect[2] - rect[0]) * (rect[3] - rect[1]) 16 var s1:String = String(rect[0]) + "_" + String(rect[1]) // bottom-left 17 var s2:String = String(rect[0]) + "_" + String(rect[3]) // top-left 18 var s3:String = String(rect[2]) + "_" + String(rect[3]) // top-right 19 var s4:String = String(rect[2]) + "_" + String(rect[1]) // bottom-right 20 if st.contains(s1) {st.remove(s1)} 21 else {st.insert(s1)} 22 if st.contains(s2) {st.remove(s2)} 23 else {st.insert(s2)} 24 if st.contains(s3) {st.remove(s3)} 25 else {st.insert(s3)} 26 if st.contains(s4) {st.remove(s4)} 27 else {st.insert(s4)} 28 } 29 var t1:String = String(min_x) + "_" + String(min_y) 30 var t2:String = String(min_x) + "_" + String(max_y) 31 var t3:String = String(max_x) + "_" + String(max_y) 32 var t4:String = String(max_x) + "_" + String(min_y) 33 if !st.contains(t1) || !st.contains(t2) || !st.contains(t3) || !st.contains(t4) || st.count != 4 34 { 35 return false 36 } 37 return area == (max_x - min_x) * (max_y - min_y) 38 } 39 }
1496ms
1 class Solution { 2 func isRectangleCover(_ rectangles: [[Int]]) -> Bool { 3 var dic = Dictionary<String,Int>() 4 var commenDic = Dictionary<String,Int>() 5 //計算面積(排除覆蓋) 6 var minX = rectangles[0][0] 7 var minY = rectangles[0][1] 8 var maxX = rectangles[0][2] 9 var maxY = rectangles[0][3] 10 var area:Int = 0 11 //計算角的個數 12 for i in rectangles{ 13 if i[0] < minX { 14 minX = i[0] 15 } 16 if i[1] < minY { 17 minY = i[1] 18 } 19 if i[2] > maxX { 20 maxX = i[2] 21 } 22 if i[3] > maxY { 23 maxY = i[3] 24 } 25 area += (i[2]-i[0]) * (i[3]-i[1]) 26 27 let p1 = String(i[0])+","+String(i[1]) 28 let p2 = String(i[0])+","+String(i[3]) 29 30 let p3 = String(i[2])+","+String(i[3]) 31 let p4 = String(i[2])+","+String(i[1]) 32 let pArr = [p1,p2,p3,p4] 33 for p in pArr{ 34 if let _ = dic[p]{ 35 dic[p] = nil 36 }else{ 37 dic[p] = 1 38 } 39 } 40 //去除遮擋 41 let p11 = p1 + ",1" 42 let p21 = p2 + ",2" 43 let p31 = p3 + ",3" 44 let p41 = p4 + ",4" 45 let pArr2 = [p11,p21,p31,p41] 46 for p in pArr2{ 47 if let _ = commenDic[p]{ 48 return false 49 }else{ 50 commenDic[p] = 1 51 } 52 } 53 } 54 if dic.count != 4{ 55 return false 56 } 57 if area != (maxY - minY) * (maxX - minX){ 58 return false 59 } 60 return true 61 } 62 }