题解 | #最大正方形#

最大正方形

http://www.nowcoder.com/practice/0058c4092cec44c2975e38223f10470e

  1. 好习惯,务必数组要初始化,因为中途不是按照顺序走的,他是跳着走的,这样的话,int数组又是随机初始化(也可能随机初始化一个很小的值,所以,务必使用vector且全部初始化0. 后续在做自己的开始初始化,以及计算值)
class Solution {
public:
    /**
     * 最大正方形
     * @param matrix char字符型vector<vector<>> 
     * @return int整型
     */
    int solve(vector<vector<char> >& matrix) {
        // write code here


        vector<vector<int>> dp(matrix.size(),vector<int>(matrix[0].size(),0));

        // 初始化 dp 矩阵的第一列
        for(int i = 0; i< matrix.size();i++){
            // 如果当前点为 1 ,那么最大正方形就是他本身,最大边长也就是 1
            dp[i][0] = matrix[i][0] - '0';
        }

        // 初始化 dp 矩阵的第一行
        for(int i = 0; i< matrix[0].size();i++){
            // 如果当前点为 1 ,那么最大正方形就是他本身,最大边长也就是 1
            dp[0][i] = matrix[0][i] - '0';
        }

        int max_ =0;
        // 遍历所有点,填充 dp 矩阵的所有位置。
        for(int i = 1; i< matrix.size(); i++){
            for(int j = 1; j< matrix[0].size();j++){

                if(matrix[i][j] == '1'){//剪枝操作了。就导致部分dp没有初始化好,有垃圾数据。

                    dp[i][j]=min(dp[i-1][j-1],dp[i-1][j]);
                    dp[i][j]=min(dp[i][j],dp[i][j-1])+1;
                    max_=max(max_,dp[i][j]);
                }
            }
        }

        return max_*max_;


    }
};
算法解析 文章被收录于专栏

这里主要是算法岗的自我思路总结

全部评论

相关推荐

10-28 11:04
已编辑
美团_后端实习生(实习员工)
一个2人:我说几个点吧,你的实习经历写的让人觉得毫无含金量,你没有挖掘你需求里的 亮点, 让人觉得你不仅打杂还摆烂。然后你的简历太长了🤣你这个实习经历看完,估计没几个人愿意接着看下去, sdk, 索引这种东西单拎出来说太顶真了兄弟,好好优化下简历吧
点赞 评论 收藏
分享
11-18 16:08
福州大学 Java
影流之主:干10年不被裁,我就能拿别人一年的钱了,日子有盼头了
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务