动态规划12(Leetcode221最大正方形)

代码:

java 复制代码
class Solution {
    public int maximalSquare(char[][] matrix) {
        int m = matrix.length;
        int n = matrix[0].length;
        int[][]area = new int[m][n];
        area[0][0] = matrix[0][0];
        int max = 0;
        for(int i=0;i<m;i++){
            area[i][0] = matrix[i][0]=='1'? 1:0;
            max = Math.max(area[i][0],max);
        }
        for(int j=0;j<n;j++){
            area[0][j] = matrix[0][j]=='1'? 1:0;
            max = Math.max(area[0][j],max);

        }
        for(int i=1;i<m;i++){
            for(int j=1;j<n;j++){
                if(matrix[i][j]=='0'){
                    area[i][j] = 0;
                }else if(area[i-1][j-1]==area[i][j-1]&&area[i-1][j-1]==area[i-1][j]){
                    area[i][j] = area[i-1][j-1]+1;
                    max = Math.max(area[i][j],max);
                }else{
                    area[i][j] = Math.min(Math.min(area[i-1][j-1],area[i-1][j]),area[i][j-1])+1;
                }              
            }
        }
        return max*max;
    }
}
相关推荐
代码探秘者16 分钟前
【算法】吃透18种Java 算法快速读写模板
数据结构·数据库·python·算法·spring
2301_8166512216 分钟前
C++模块化设计原则
开发语言·c++·算法
gaozhiyong081317 分钟前
提示词的解剖学:Gemini 3.1 Pro 提示工程高级策略与国内实战
人工智能·算法·机器学习
小范自学编程37 分钟前
算法训练营Day44 - 动态规划part12
算法·动态规划
。。,……~38 分钟前
RGB-IR融合算法CDDFUSE理解+复现
算法
小刘的AI小站40 分钟前
L9 Policy Gradient Method (二)
算法·机器学习·强化学习
WolfGang0073211 小时前
代码随想录算法训练营 Day21 | 回溯算法 part03
数据结构·算法
tankeven1 小时前
HJ152 取数游戏
c++·算法
程序员Shawn1 小时前
【机器学习 | 第六篇】- 机器学习
人工智能·算法·机器学习·集成学习
深邃-1 小时前
数据结构-队列
c语言·数据结构·c++·算法·html5