动态规划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;
    }
}
相关推荐
滴滴答滴答答27 分钟前
LeetCode Hot100 之 16 合并两个有序链表
算法·leetcode·链表
ASKED_20191 小时前
企业级大模型微调(Fine-tuning)策略
大数据·人工智能·算法
t198751281 小时前
基于Chirp分解和多相快速算法的离散分数傅里叶变换(DFRFT)MATLAB实现
开发语言·算法·matlab
愚者游世1 小时前
力扣解决二进制 | 题型常用知识点梳理
c++·程序人生·算法·leetcode·职场和发展
阿星AI工作室2 小时前
宝藏skills!90个顶尖博客信源自动抓,AI每天帮我筛出20篇精华!
人工智能·算法
Ulyanov2 小时前
基于Python的单脉冲雷达导引头回波生成技术
python·算法·仿真·单脉冲雷达、
ersaijun2 小时前
机器人动力学库Pinocchio、RBDL 和 KDL区别
算法·机器人·控制·开源库
sali-tec2 小时前
C# 基于OpenCv的视觉工作流-章25-ORB特征点
图像处理·人工智能·opencv·算法·计算机视觉
jghhh013 小时前
LT喷泉码编解码的MATLAB实现
数据库·算法·matlab
被遗忘在角落的死小孩3 小时前
抗量子 Winternitz One Time Signature(OTS) 算法学习
学习·算法·哈希算法