★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
➤微信公衆號:山青詠芝(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 0
s and 1
s, 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 1
s).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
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 }