问题描述:
题目链接:221 Maximal Square
问题找解决的是给出一个M*N的矩阵, 只有'1', '0',两种元素; 需要你从中找出 由'1'组成的最大正方形。恩, 就是这样。
我们看到, 这道题目的标签还是DP, 那么问题的关键就是要找到一个符合判断是否为正方形的递推式。
老套路, 先看基本型, 对于一个2*2的正方形,对于右下角的元素(1,1)而言, 他的上(0,1), 左(1,0), 左上(0,0)三个元素应该都是'1',
如此才能够组成一个合规的正方形; 那么如果是一个3*3呢, 首先他必然是一个2*2, 然后左加一列,上添一行,就由一个2*2成了一个3*3型,所以, 对于在矩阵中的
任意一个点'1'只要不断匹配他的左边列和上边行都是‘1’, 并计数后再往外匹配一层,知道出现'0'或者到达边界即可, 然后从每个点中选出匹配到的最大层数, done!
基本套路就是如此, 但是每个点都走一遍就是M*N个点, 后每个点都再外面一层逐个匹配, 时间复杂度消耗不起,O(M^2*N^2), 一般考虑M*N,直接近似4次方的复杂度,
肯定不可取。既然从后往前不靠谱, 那我们从前往后推又如何呢?
除去边界(即第一行与第一列),对于任意一个matrix[i][i],他所处的方形应该前一层决定:左边(matrix[i][j-1]), 上边(matrix[i-1][j]),左上(matrix[i-1][j-1])决定,
同样的, 我们也需要一个结果矩阵 ret[M][N] 记录每个对应点所处的方形层数。
再看最基本型:对于在matrix[1][1]出的点, 他的左上外层全为'1', 故这个点在ret[1][1]就+1,结果记为2,
即:if: (top != '0', left!='0', top_left!='0')
then: ret[i][j] = matrix[i][j]+1;
在考虑到这一步的时候, 觉得已经ok了, 立刻在页面写好代码提交, 结果却是一个大大的Wrong Answer! 当下觉得没错啊, 对于每个点是不是处于方形都做了
判断, 而且判定了之后还把层数+1嘞,于是输出结果矩阵一看:
很明显, 对于层数计算, 并没有获取前一层的都处于的方形层数, 要知道,假设在[i][j]为止是属于3*3的方形, 那么必然有点[i-1][j],[i][j-1], [i-1][j-1]这3个都至少属于
2*2的方形, 可能用图示更清楚:
left:top:left_top:
所以上面的情形如果在递推产生的ret矩阵中就是这个样子:
left:top:left_top:
所以, 更正后的递推式应该是:
再次提交, Accepted!
最后只解决的代码:
另外, 还有一道相近的(链接在这里), 这次不定形状了, 你是一行, 还是正方形没有限制了, 难度也提升为Hard级别,
但核心思想肯定没变, 各位额可以尝试下, 此题明后日贴个人解决思路。
最后还是老话, 本人贴上来的解法和思路仅作是记录,或者还可以向各位看官交流学习,有帮助就好。
leetcode每日解题思路 221 Maximal Square的更多相关文章
-
Java for LeetCode 221 Maximal Square
Given a 2D binary matrix filled with 0's and 1's, find the largest square containing all 1's and ret ...
-
【LeetCode】221. Maximal Square
Maximal Square Given a 2D binary matrix filled with 0's and 1's, find the largest square containing ...
-
求解最大正方形面积 — leetcode 221. Maximal Square
本来也想像园友一样,写一篇总结告别 2015,或者说告别即将过去的羊年,但是过去一年发生的事情,实在是出乎平常人的想象,也不具有代表性,于是计划在今年 6 月份写一篇 "半年总结" ...
-
leetcode array解题思路
Array *532. K-diff Pairs in an Array 方案一:暴力搜索, N平方的时间复杂度,空间复杂度N 数组长度为10000,使用O(N平方)的解法担心TLE,不建议使用,尽管 ...
-
[LeetCode] 3Sum 解题思路
Given an array S of n integers, are there elements a, b, c in S such that a + b + c = 0? Find all un ...
-
【LeetCode】221. Maximal Square 解题报告(Python & C++)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 动态规划 日期 题目地址: https://leet ...
-
[LeetCode] 221. Maximal Square 最大正方形
Given a 2D binary matrix filled with 0's and 1's, find the largest square containing all 1's and ret ...
-
(medium)LeetCode 221.Maximal Square
Given a 2D binary matrix filled with 0's and 1's, find the largest square containing all 1's and ret ...
-
[LeetCode] 221. Maximal Square _ Medium Tag: Dynamic Programming
Given a 2D binary matrix filled with 0's and 1's, find the largest square containing only 1's and re ...
随机推荐
-
多通道(Multichannel)单通道(singlechannel)图像概念梳理
在做机器视觉时,常常要将一个多通道图像分离成几个单通道图像或者将几个单通道图像合成一个多通道图像,以方便图像处理,但是.写这篇博客,是为加深对这两个概念的理解,下面会给出部分OpenCV对单通道与多通 ...
-
sql语句原则
整理尘封的文档,sql语句方面的几条原则再次回顾一下.更详细版本 1. 尽量使用临时表扫描替代全表扫描: 2. 抛弃in和not in语句,使用exists和not exists替代:IN和EXIST ...
-
SQL Server 的事务和锁(二)-Range S-S锁
在这篇随笔中,我们的主要关注点在 Key-Range Lock.Key-Range Lock有 S-S.S-U.I-N.X-X几种情况.我们一个一个来说,力求明白.遗憾的是,这里可能会比较冗长,那么死 ...
-
Webdriver API (三)- actions
Actions类主要定义了一些模拟用户的鼠标mouse,键盘keyboard操作.对于这些操作,使用perform()方法进行执行. actions类可以完成单一的操作,也可以完成几个操作的组合. 有 ...
-
MySQl 存储过程+游标
DROP PROCEDURE IF exists pro_Insertflightplan_stat; create procedure pro_Insertflightplan_stat(exec ...
-
Django之auth模块(用户认证)
auth模块简介 auth模块是对登录认证方法的一种封装,之前我们获取用户输入的用户名及密码后需要自己从user表里查询有没有用户名和密码符合的对象, 而有了auth模块之后就可以很轻松的去验证用户的 ...
-
前端开发面试题-HTML(转载)
本文由 本文的原作者markyun 收集总结了一些前端面试题,初学者阅后也要用心钻研其中的原理,重要知识需要系统学习.透彻学习,形成自己的知识链.万不可投机取巧,临时抱佛脚只求面试侥幸混过关是错误的! ...
-
epoll使用详解
目录 epoll介绍 Epoll的优点: 1.支持一个进程打开大数目的socket描述符(FD) 2.IO效率不随FD数目增加而线性下降 3.支持边缘触发模式 4.使用mmap加速内核与用户空间的消息 ...
-
总结 : C#事件理解
要理解事件,首先必须理解委托!! 1.如果说委托是一个类型,那么事件就是一个对象! 2.事件的创建必须是借助某个委托类型来完成的! 3.也就是说,委托是事件的类型,事件本身是个对象!! 4.所以,事件 ...
-
leetcode 二叉搜索树中第K小的元素 python
二叉搜索树中第K小的元素 给定一个二叉搜索树,编写一个函数 kthSmallest 来查找其中第 k 个最小的元素. 说明:你可以假设 k 总是有效的,1 ≤ k ≤ 二叉搜索树元 ...