程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> C++入門知識 >> LeetCode -- Maximal Square

LeetCode -- Maximal Square

編輯:C++入門知識

LeetCode -- Maximal Square


題目描述:


Given a 2D binary matrix filled with 0's and 1's, find the largest square containing all 1's and return its area.


For 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.




在一個矩陣中,找到最大的正方形面積(1表示正方形的點,0表示空)。




本題是很典型的DP問題。


1. 把dp[0,i]賦值為matrix[0,i] , dp[i,0]賦值為matrix[i,0]。i∈[0,n)


2. 兩層循環根據不同情況為dp[i,j]賦值:
a. matrix[i,j] == 1 且3個鄰居(dp[i-1,j],dp[i,j-1],dp[i-1,j-1])均為1 : dp[i,j] = 4
b. matrix[i,j] == 1 且3個鄰居>1且相等: dp[i,j] = (鄰居面積的平方根+1)的平方
c. matrix[i,j] == 1 且3個鄰居>=1但不一定相等: dp[i,j]=(鄰居中最小值的平方根+1)的平方
d. 其他情況: dp[i,j] = matrix[i,j]


3.使用max變量來track當前dp[i,j]的最值


實現代碼:




public class Solution {
    public int MaximalSquare(char[,] matrix) {
        
        var row = matrix.GetLength(0);
        var col = matrix.GetLength(1);
        if(row < 2){
            if(row == 0){
				return 0;
			}
			else if(col == 1){
				return matrix[0,0] == '1' ? 1 : 0;
			}
        }
        var max = 0;
		
        var dp = new int[row, col];
        for(var i = 0;i < row; i++){
            var x = matrix[i,0] == '1' ? 1 : 0;
			dp[i, 0] = x;
			
			if(dp[i,0] > max){max = dp[i,0];}
        }
        for(var i = 0;i < col; i++){
            var x = matrix[0,i] == '1' ? 1 : 0;
			dp[0, i] = x;
			if(dp[0,i] > max){max = dp[0,i];}
        }
        
        for(var i = 1;i < row; i++){
            for(var j = 1;j < col; j++){
				// neighbours all equals 1
                if(matrix[i,j] == '1' && dp[i-1,j] == 1 && dp[i, j-1] == 1 && dp[i-1,j-1] == 1){
					if(dp[i-1, j] == 1){
						dp[i,j] = 4;
					}
                }
				// neighbours all bigger than 1 and equals each other
				else if(matrix[i,j] == '1' && dp[i-1,j] == dp[i,j-1] && dp[i-1,j-1] == dp[i-1,j] && dp[i-1,j] > 1){
					dp[i,j] = (int)Math.Pow(Math.Sqrt(dp[i,j-1]) + 1,2);
				}
				// neighbours all no less than 1, but may not equals each other
				else if(matrix[i,j] == '1' && dp[i-1,j] >= 1 && dp[i,j-1] >= 1 && dp[i-1,j-1] >= 1){
					var min = Math.Min(Math.Min(dp[i-1,j-1], dp[i-1,j]), dp[i,j-1]);
					dp[i,j] = (int)Math.Pow(Math.Sqrt(min) + 1,2);
				}
                else{
                    dp[i,j] = matrix[i,j] == '1' ? 1 : 0;
                }
				
				if(dp[i,j] > max){max = dp[i,j];}
            }
        }
		
        return max;
        
    }
}


 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved