题目链接:https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&problem=2868

用暴力也过了:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<cmath>
#include<queue>
#include<vector>
#include<map>
#include<string>
#include<set>
#define LL long long
#define MAX(a,b) (a>b?a:b)
#define MIN(a,b) (a<b?a:b) using namespace std; int a[1050][1050];
int n,m;
int ans = 0; int test(int x, int y, int len)
{
    for(int i = x; i<x+len; i++)
    for(int j = y; j<y+len; j++)
    {
        if(a[i][j]==0) return 0;
    }
    return 1;
} int main()
{
    while(scanf("%d%d",&n,&m) && (m||n))
    {
        ans = 0;
        for(int i = 1; i<=n; i++)
        for(int j = 1; j<=m; j++)
            scanf("%d",&a[i][j]);         for(int i = 1; i<=n; i++)
        for(int j = 1; j<=m; j++)
        {
            if(a[i][j])
            for(int len = 1; j+len-1<=m && i+len-1<=n; len++)
            {
                if(len<=ans)//这一步很重要,如果长度都比ans小,那再去比较也无意义了。少了这一句就少时了。
                    continue;                 if(test(i,j,len))
                    ans = MAX(ans,len);                 else break;
            }
        }
        printf("%d\n",ans);     }
    return 0;
}

然后使用dp,画图找找规律。dp[i][j]为当前格子作为右下角能达到的最大正方形边长,可知dp[i][j] 只与dp[i-1][j] ,dp[i][j-1] ,dp[i-1][-1j]有关。所以可以得到状态转移方程:dp[i][j] = 1 + MMIN(dp[i-1][j],dp[i][j-1],dp[i-1][j-1])

代码如下:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<cmath>
#include<queue>
#include<vector>
#include<algorithm>
#include<map>
#include<string>
#include<set>
#define LL long long
#define MAX(a,b) (a>b?a:b)
#define MIN(a,b) (a<b?a:b)
#define MMIN(a,b,c) (MIN(a,b)<c?MIN(a,b):c) using namespace std; int a[1050][1050];
int dp[1050][1050]; int n,m;
int ans = 0; int main()
{
while(scanf("%d%d",&n,&m) && (m||n))
{
ans = 0;
for(int i = 1; i<=n; i++)
for(int j = 1; j<=m; j++)
{
dp[i][j] = 0;
scanf("%d",&a[i][j]);
if(a[i][j])
{
dp[i][j] = 1 + MMIN(dp[i-1][j],dp[i][j-1],dp[i-1][j-1]);
} ans = MAX(dp[i][j],ans);
}
printf("%d\n",ans);
}
return 0;
}

最新文章

  1. centos6.X使用Apache+Mono搭建asp.net 环境
  2. 新增资产时YTD折旧与累计折旧录入错误如何处理
  3. 蓝牙—RFCOMM协议
  4. 一天一个Java基础——序列化
  5. Nginx负载均衡SFTP
  6. 【07】为多态基类声明virtual析构方法
  7. spring 定时任务的 执行时间设置规则
  8. poj 3422 Kaka&#39;s Matrix Travels 费用流
  9. HDU 2544 最短路 SPFA 邻接表 模板
  10. github使用介绍
  11. LeetCode之“动态规划”:Triangle
  12. 移动web技能总结
  13. 查看windows上次开机时间
  14. 安卓TP驱动开发
  15. storm的可靠性
  16. java 添加到数据库的数据没有时分秒
  17. 根据MAC地址前6位知道网络设备是哪家公司生产的
  18. 安装CentOS 7.4 可能会出现的坑以及解决方案
  19. springboot示例参考网站
  20. centos set up samba

热门文章

  1. Java 对象的序列化、反序列化
  2. 转 Tesseract-OCR 字符识别---样本训练
  3. 使用viewPage实现图片轮播
  4. 邁向IT專家成功之路的三十則鐵律 鐵律十:IT人思維之道-跳脫框架
  5. 【redis】4.spring boot集成redis,实现数据缓存
  6. 【java】spring项目中 对entity进行本类间的克隆
  7. 如何用迅雷下载在网页中的Flash动画或课件
  8. linux中ERROR: The partition with /var/lib/mysql is too full!解决的方法
  9. java中Volatile修饰符的含义
  10. NoSQL数据库-MongoDB和Redis