动态规划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;
    }
}
相关推荐
通信小呆呆15 小时前
当算法有了“五感”:多模态数据融合如何向人体感官协同学习?
人工智能·学习·算法·机器学习·机器人
benben04415 小时前
强化学习之DQN算法族(基于gymnasium开发)
算法
何以解忧,唯有..16 小时前
Go语言循环语句详解:for、range与循环控制
开发语言·算法·golang
想吃火锅100517 小时前
【leetcode】88.合并两个有序数组js
算法
生成论实验室18 小时前
机器人:一个自主运动的系统
人工智能·算法·语言模型·机器人·自动驾驶·agi·安全架构
Qres82118 小时前
算法复键——树状数组
数据结构·算法
H1785350909618 小时前
SolidWorks第四部分_直接实体建模特征9_替换面原理
线性代数·算法·机器学习·3d建模·solidworks
不会就选b18 小时前
算法日常・每日刷题--<二分查找>3
算法
绿算技术18 小时前
Mooncake 与绿算ForinnBase GroundPool如何联手打破推理僵局?
科技·算法·架构