算法测试题(实心矩阵)

前几天,收到一个面试题,发现某度、google等平台都没有合适的解答,我在这里把我的求解方法在这里展示一下,大家可以适当借鉴(蛮多判断可以适当的优化,大家可以自行处理)。

有一个n*n的矩阵,矩阵由 "0"和"1"组成,写一个算法检测矩阵中的所有"1"组成的图形是一个实心的正方形,结果为true或者false。

例如

0 0 1 1

0 0 1 1

0 0 0 0

0 0 0 0

结果为true;


1 1 1 1

1 0 0 1

1 0 0 1

1 1 1 1

结果为false;


0 0 1 1

0 0 1 1

0 1 0 0

0 0 0 0

结果为false;


1 1 1 1

1 1 1 1

1 1 1 1

1 1 1 1

结果为true

解决思路:

          1.获取 1的总个数;

          2.根据1的个数对特殊情况判断(全0或者全1)

          3.获取第一个1往左1的个数和向下1的个数

          4.根据向右以及向下1的个数以及1的总数做最终判断

代码展示:





以上就是我给出的解决方案。

第二种方案:http://www.jianshu.com/p/0edab75e1d16







最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 五天前的同一个题目,现在又有了新的思路,这种方法更清晰一点,代码量差不多。仅供参考。 有一个n*n的矩阵,矩阵由 ...
    MardaWang阅读 3,680评论 0 3
  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 14,353评论 0 33
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,750评论 19 139
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 32,044评论 18 399
  • 我就这样离开 回不到那天早晨 一缕清风 几许微凉 不忍熟睡人 醒来 我就这样离开 为观浪弄潮 去寻找蔚蓝的大海 我...
    林柳枫阅读 760评论 0 0