[Swift]LeetCode827. 最大人工島 | Making A Large Island

★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
➤微信公衆號:山青詠芝(shanqingyongzhi)
➤博客園地址:山青詠芝(https://www.cnblogs.com/strengthen/
➤GitHub地址:https://github.com/strengthen/LeetCode
➤原文地址: http://www.javashuo.com/article/p-swuwmgux-me.html 
➤若是連接不是山青詠芝的博客園地址,則多是爬取做者的文章。
➤原文已修改更新!強烈建議點擊原文地址閱讀!支持做者!支持原創!
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★html

In a 2D grid of 0s and 1s, we change at most one 0 to a 1.git

After, what is the size of the largest island? (An island is a 4-directionally connected group of 1s).github

Example 1:微信

Input: [[1, 0], [0, 1]]
Output: 3
Explanation: Change one 0 to 1 and connect two 1s, then we get an island with area = 3.

Example 2:app

Input: [[1, 1], [1, 0]]
Output: 4
Explanation: Change the 0 to 1 and make the island bigger, only one island with area = 4.

Example 3:spa

Input: [[1, 1], [1, 1]]
Output: 4
Explanation: Can't change any 0 to 1, only one island with area = 4. 

Notes:code

  • 1 <= grid.length = grid[0].length <= 50.
  • 0 <= grid[i][j] <= 1.

在二維地圖上, 0表明海洋, 1表明陸地,咱們最多隻能將一格 0 海洋變成 1變成陸地。htm

進行填海以後,地圖上最大的島嶼面積是多少?(上、下、左、右四個方向相連的 1 可造成島嶼)blog

示例 1:get

輸入: [[1, 0], [0, 1]]
輸出: 3
解釋: 將一格0變成1,最終連通兩個小島獲得面積爲 3 的島嶼。

示例 2:

輸入: [[1, 1], [1, 0]]
輸出: 4
解釋: 將一格0變成1,島嶼的面積擴大爲 4。

示例 3:

輸入: [[1, 1], [1, 1]]
輸出: 4
解釋: 沒有0能夠讓咱們變成1,面積依然爲 4。

說明:

  • 1 <= grid.length = grid[0].length <= 50
  • 0 <= grid[i][j] <= 1

Runtime: 104 ms
Memory Usage: 19.9 MB
 1 class Solution {
 2     var N:Int = 0
 3     func largestIsland(_ grid: [[Int]]) -> Int {
 4         var grid = grid
 5         N = grid.count
 6         var index:Int = 3
 7         var res:Int = 0
 8         var area:[Int:Int] = [Int:Int]()
 9         for x in 0..<N
10         {
11             for y in 0..<N
12             {
13                 if grid[x][y] == 1
14                 {
15                     area[index] = dfs(&grid, x, y, index)
16                     res = max(res, area[index,default:0])
17                     index += 1
18                 }
19             }
20         }
21         for x in 0..<N
22         {
23             for y in 0..<N
24             {
25                 if grid[x][y] == 0
26                 {
27                     var seen:Set<Int> = Set<Int>()
28                     var cur:Int = 1
29                     for (key,val) in move(x, y)
30                     {
31                         index = grid[key][val]
32                         if index > 1 && !seen.contains(index)
33                         {
34                             seen.insert(index)
35                             cur += area[index,default:0]
36                         }
37                     }
38                     res = max(res, cur)
39                 }
40             }
41         }
42         return res
43     }
44     
45     func move(_ x:Int,_ y:Int) -> [(Int,Int)]
46     {
47         var res:[(Int,Int)] = [(Int,Int)]()
48         if valid(x, y + 1) {res.append((x, y + 1))}
49         if valid(x, y - 1) {res.append((x, y - 1))}
50         if valid(x + 1, y) {res.append((x + 1, y))}
51         if valid(x - 1, y) {res.append((x - 1, y))}
52         return res        
53     }
54     
55     func valid(_ x:Int,_ y:Int) -> Bool
56     {
57         return 0 <= x && x < N && 0 <= y && y < N
58     }
59     
60     func dfs(_ grid:inout [[Int]],_ x:Int,_ y:Int,_ index:Int) -> Int
61     {
62         var area:Int = 0
63         grid[x][y] = index
64         for (key,val) in move(x, y)
65         {
66             if grid[key][val] == 1
67             {
68                 area += dfs(&grid, key, val, index) 
69             }
70         }
71         return area + 1
72     }
73 }
相關文章
相關標籤/搜索