★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
➤微信公衆號:山青詠芝(shanqingyongzhi)
➤博客園地址:山青詠芝(https://www.cnblogs.com/strengthen/)
➤GitHub地址:https://github.com/strengthen/LeetCode
➤原文地址:http://www.javashuo.com/article/p-yniswhsj-kt.html
➤若是連接不是山青詠芝的博客園地址,則多是爬取做者的文章。
➤原文已修改更新!強烈建議點擊原文地址閱讀!支持做者!支持原創!
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★html
Given a 2D grid
of 0
s and 1
s, return the number of elements in the largest square subgrid that has all 1
s on its border, or 0
if one doesn't exist. git
Example 1:github
Input: grid = [[1,1,1],[1,0,1],[1,1,1]] Output: 9
Example 2:微信
Input: grid = [[1,1,0,0]] Output: 1
Constraints:ide
1 <= grid.length <= 100
1 <= grid[0].length <= 100
grid[i][j]
is 0
or 1
給你一個由若干 0
和 1
組成的二維網格 grid
,請你找出邊界所有由 1
組成的最大 正方形 子網格,並返回該子網格中的元素數量。若是不存在,則返回 0
。 spa
示例 1:code
輸入:grid = [[1,1,1],[1,0,1],[1,1,1]] 輸出:9
示例 2:htm
輸入:grid = [[1,1,0,0]] 輸出:1
提示:blog
1 <= grid.length <= 100
1 <= grid[0].length <= 100
grid[i][j]
爲 0
或 1
1 class Solution { 2 func largest1BorderedSquare(_ grid: [[Int]]) -> Int { 3 var naxNum:Int = 0 4 let m:Int = grid.count 5 let n:Int = grid[0].count 6 var hor:[[Int]] = [[Int]](repeating:[Int](repeating:0,count:n),count:m) 7 var ver:[[Int]] = [[Int]](repeating:[Int](repeating:0,count:n),count:m) 8 for i in 0..<m 9 { 10 for j in 0..<n 11 { 12 if grid[i][j] == 1 13 { 14 // auxillary horizontal array 15 hor[i][j] = (j == 0) ? 1 : hor[i][j-1] + 1 16 // auxillary vertical array 17 ver[i][j] = (i == 0) ? 1 : ver[i-1][j] + 1 18 } 19 } 20 } 21 for i in stride(from:m - 1,through:0,by:-1) 22 { 23 for j in stride(from:n - 1,through:0,by:-1) 24 { 25 // choose smallest of horizontal and vertical value 26 var small:Int = min(hor[i][j], ver[i][j]) 27 while (small > naxNum) 28 { 29 // check if square exists with 'small' length 30 if ver[i][j-small+1] >= small && hor[i-small+1][j] >= small 31 { 32 naxNum = small 33 } 34 small -= 1 35 } 36 } 37 } 38 return naxNum * naxNum 39 } 40 }
104mselement
1 class Solution { 2 private func checkBottomRight(_ grid: [[Int]], row: Int, col: Int, length: Int) -> Bool { 3 guard length > 1 else { 4 return true 5 } 6 7 for i in 0..<length { 8 if grid[row + i][col + length - 1] != 1 || grid[row + length - 1][col + i] != 1 { 9 return false 10 } 11 } 12 return true 13 } 14 15 func largest1BorderedSquare(_ grid: [[Int]]) -> Int { 16 var maxLength = 0 17 for row in 0..<grid.count { 18 for col in 0..<grid[row].count { 19 guard grid[row][col] == 1 else { 20 continue 21 } 22 23 var i = 1 24 while row + i < grid.count && grid[row + i][col] == 1 && col + i < grid[row].count && grid[row][col + i] == 1 { 25 i += 1 26 } 27 while i > maxLength && !self.checkBottomRight(grid, row: row, col: col, length: i) { 28 i -= 1 29 } 30 maxLength = Swift.max(maxLength, i) 31 } 32 } 33 return maxLength * maxLength 34 } 35 }
120ms
1 class Solution { 2 3 func largest1BorderedSquare(_ grid: [[Int]]) -> Int { 4 var ans = 0 5 let rowSize = grid.count 6 let colSize = grid[0].count 7 8 func valid(x: Int,y: Int, edgeLength: Int) -> Bool { 9 let lastY = y + edgeLength - 1 10 let lastX = x + edgeLength - 1 11 for i in x...lastX { 12 if grid[i][y] == 0 || grid[i][lastY] == 0{ 13 return false 14 } 15 } 16 for j in y...lastY { 17 if grid[x][j] == 0 || grid[lastX][j] == 0 { 18 return false 19 } 20 } 21 return true 22 } 23 for i in 0..<rowSize { 24 for j in 0..<colSize { 25 if grid[i][j] == 1 { 26 if ans == 0 { 27 ans = 1 28 } 29 if i != rowSize - 1 && j != colSize - 1 { 30 //---->right 31 var m = j + 1 32 while m < colSize && grid[i][m] == 1 { 33 m += 1 34 } 35 var n = i + 1 36 while n < rowSize && grid[n][j] == 1 { 37 n += 1 38 } 39 var squreLength = min(n - i, m - j) 40 while squreLength > ans { 41 if valid(x: i, y: j, edgeLength: squreLength) { 42 ans = squreLength 43 } 44 squreLength -= 1 45 } 46 } 47 } 48 } 49 } 50 return ans * ans 51 } 52 }
124 ms
1 class Solution { 2 func largest1BorderedSquare(_ grid: [[Int]]) -> Int { 3 guard !grid.isEmpty, !grid[0].isEmpty else { return 0 } 4 5 let m = grid.count 6 let n = grid[0].count 7 var horizontal = Array(repeating: Array(repeating: 0, count: n), count: m) 8 var vertical = Array(repeating: Array(repeating: 0, count: n), count: m) 9 10 for i in 0..<m { 11 for j in 0..<n { 12 if grid[i][j] > 0 { 13 horizontal[i][j] = j == 0 ? 1 : horizontal[i][j-1] + 1 14 vertical[i][j] = i == 0 ? 1 : vertical[i-1][j] + 1 15 } 16 } 17 } 18 19 for l in (1...min(m,n)).reversed() { 20 for i in (0..<m-l+1) { 21 for j in (0..<n-l+1) { 22 if vertical[i+l-1][j] >= l, vertical[i+l-1][j+l-1] >= l, 23 horizontal[i][j+l-1] >= l, horizontal[i+l-1][j+l-1] >= l { 24 return l * l 25 } 26 } 27 } 28 } 29 30 return 0 31 } 32 }
244ms
1 class Solution { 2 func largest1BorderedSquare(_ grid: [[Int]]) -> Int { 3 let M = grid.count 4 let N = grid[0].count 5 var left = [[Int]](repeating:[Int](repeating:0, count: N), count: M) 6 var top = [[Int]](repeating:[Int](repeating:0, count: N), count: M) 7 for i in grid.indices { 8 for j in grid[0].indices { 9 if grid[i][j] == 1{ 10 left[i][j] = j > 0 ? left[i][j-1] + 1 : 1 11 top[i][j] = i > 0 ? top[i-1][j] + 1 : 1 12 } 13 } 14 } 15 for l in stride(from: min(M, N), to: 0, by: -1) { 16 for i in stride(from: 0, to: M - l + 1, by: 1) { 17 for j in stride(from: 0, to: N - l + 1, by: 1) { 18 if top[i + l - 1][j] >= l 19 && top[i + l - 1][j + l - 1] >= l 20 && left[i][j + l - 1] >= l 21 && left[i + l - 1][j + l - 1] >= l { 22 return l * l 23 } 24 } 25 } 26 } 27 return 0 28 } 29 }