(nice!!!)(LeetCode 每日一题) 1277. 统计全为 1 的正方形子矩阵 (动态规划)

题目:1277. 统计全为 1 的正方形子矩阵

思路:动态规划dp,时间复杂度0(nm)。

考虑每个点,作为正方形的右下角的情况,有多少个正方形。这就需要知道最大可能的正方形长度,假设点(x,y)的最大可能的正方形长度是a,那么就有a个。

而如何找到最大的长度,其实可以由(x-1,y)、(x-1,y-1)、(x,y-1)这三个点的最大长度推出,其实就是三者的最大长度的最小值+1,即:vi+1j+1=min({vij,vi+1j,vij+1})+1。这里用到的就是动态规划

大神的思路

C++版本:

cpp 复制代码
class Solution {
public:
    int countSquares(vector<vector<int>>& matrix) {
        int n=matrix.size(),m=matrix[0].size();
        
        vector<vector<int>> v(n+1,vector<int>(m+1,0));
        int ans=0;
        for(int i=0;i<n;i++){
            for(int j=0;j<m;j++){
                if(matrix[i][j]==1){
                    v[i+1][j+1]=min({v[i][j],v[i+1][j],v[i][j+1]})+1;
                    ans+=v[i+1][j+1];
                }
            }
        }
        return ans;
    }
};

JAVA版本:

java 复制代码
class Solution {
    public int countSquares(int[][] matrix) {
        int n=matrix.length,m=matrix[0].length;
        int[][] v=new int[n+1][m+1];
        int ans=0;
        for(int i=0;i<n;i++){
            for(int j=0;j<m;j++){
                if(matrix[i][j]==1){
                    v[i+1][j+1]=Math.min(Math.min(v[i][j],v[i+1][j]),v[i][j+1])+1;
                    ans+=v[i+1][j+1];
                }
            }
        }
        return ans;
    }
}

GO版本:

go 复制代码
func countSquares(matrix [][]int) int {
    n,m:=len(matrix),len(matrix[0])
    v:=make([][]int,n+1)
    for i:=range v {
        v[i]=make([]int,m+1)
    }
    ans:=0
    for i:=0;i<n;i++ {
        for j:=0;j<m;j++ {
            if matrix[i][j]==1 {
                v[i+1][j+1]=min(min(v[i][j],v[i+1][j]),v[i][j+1])+1
                ans+=v[i+1][j+1]
            }
        }
    }
    return ans

}
相关推荐
沈浩(种子思维作者)2 小时前
没有错误,正确将一文不值
人工智能·python·算法·量子计算
x_xbx2 小时前
LeetCode:5. 最长回文子串
算法·leetcode·职场和发展
快手技术2 小时前
免费报名|生成式推荐技术如何实现体系化演进?快手技术沙龙第四期开启!
算法
初夏睡觉2 小时前
数字截断求和 题解
算法
AZaLEan__2 小时前
多源 BFS
java·开发语言·算法
程序员卷卷狗2 小时前
Java转Go面试速记:Go基础22问,一篇理清高频易错点一篇理清高频易错点
java·面试·golang
喵个咪2 小时前
AI重构软件开发范式:框架与脚手架为何仍是生产级开发的刚需?
架构·go·ai编程
zzzzz3692 小时前
快速搭建SpringAi项目 集成智能问答,RAG,FUINCTION_CALLING等功能
java·ai编程
smith成长之旅2 小时前
07 | Mem0 框架分析:三路信号融合——语义 + BM25 + Entity Boost 的混合检索
python·算法
wabs6662 小时前
关于贪心算法章节的【有两个维度问题】的自我总结
算法·贪心算法