[Swift]LeetCode391. 完美矩形 | Perfect Rectangle

原文地址: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 }
相關文章
相關標籤/搜索