摘要:類似這種需要遍歷矩陣或數(shù)組來判斷,或者計算最優(yōu)解最短步數(shù),最大距離,的題目,都可以使用遞歸。
Problem
Given a 2D binary matrix filled with 0"s and 1"s, find the largest square containing all 1"s and return its area.
ExampleFor example, given the following matrix:
1 0 1 0 0 1 0 1 1 1 1 1 1 1 1 1 0 0 1 0 Return 4.Note
類似這種需要遍歷矩陣或數(shù)組來判斷True or False,或者計算最優(yōu)解(最短步數(shù),最大距離,etc)的題目,都可以使用遞歸。
所以,找矩陣內(nèi)存在的最大正方形,需要:
構(gòu)造傳遞方程:用dpi存儲以當前點matrixi作為正方形右下角頂點,所存在的最大正方形的邊長,由matrixi左、上、左上三點的dp值共同判定;
初始化邊界:matrix的第一列和第一行;
自頂向下遞推dp并更新max,找到max的最大值求平方得最優(yōu)解。
Corresponding dp matrix:
0 0 0 0 0 0 0 1 0 1 0 0 0 1 0 1 1 1 0 1 1 1 2 2 0 1 0 0 1 0
mLen = 2, the maximum dp[i] = 2 appeared twice, indicating that there are two maximal squares.
Solutionpublic class Solution { public int maxSquare(int[][] matrix) { int mLen = 0; int m = matrix.length, n = matrix[0].length; int[][] dp = new int[m+1][n+1]; for (int i = 1; i <= m; i++) { for (int j = 1; j <= n; j++) { if (matrix[i-1][j-1] == 1) { dp[i][j] = Math.min(dp[i-1][j-1], Math.min(dp[i-1][j], dp[i][j-1]))+1; mLen = Math.max(mLen, dp[i][j]); } } } return mLen * mLen; } }
文章版權歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/65472.html
摘要:動態(tài)規(guī)劃法建立空數(shù)組從到每個數(shù)包含最少平方數(shù)情況,先所有值為將到范圍內(nèi)所有平方數(shù)的值賦兩次循環(huán)更新,當它本身為平方數(shù)時,簡化動態(tài)規(guī)劃法四平方和定理法 Problem Given a positive integer n, find the least number of perfect square numbers (for example, 1, 4, 9, 16, ...) whi...
摘要:題目解答第一眼看這道題以為是個搜索問題,所以用解了一下發(fā)現(xiàn)邊界并沒有辦法很好地限定成一個,所以就放棄了這個解法。 題目:Given a 2D binary matrix filled with 0s and 1s, find the largest square containing all 1s and return its area. For example, given the ...
摘要:但如果它的上方,左方和左上方為右下角的正方形的大小不一樣,合起來就會缺了某個角落,這時候只能取那三個正方形中最小的正方形的邊長加了。假設表示以為右下角的正方形的最大邊長,則有當然,如果這個點在原矩陣中本身就是的話,那肯定就是了。 Maximal Square Given a 2D binary matrix filled with 0s and 1s, find the larges...
1 0 1 0 0 1 0 1 1 1 1 1 1 1 1 1 0 0 1 0 return 4 // O(mn) space public class Solution { public int maximalSquare(char[][] matrix) { if(matrix == null || matrix.length == 0) return 0; ...
Problem Given a string s and a dictionary of words dict, determine if s can be break into a space-separated sequence of one or more dictionary words. Example Given s = lintcode, dict = [lint, code]. R...
閱讀 1863·2021-10-09 09:44
閱讀 3393·2021-09-28 09:35
閱讀 1385·2021-09-01 10:31
閱讀 1673·2019-08-30 15:55
閱讀 2714·2019-08-30 15:54
閱讀 939·2019-08-29 17:07
閱讀 1385·2019-08-29 15:04
閱讀 2012·2019-08-26 13:56