Given a m x n matrix, if an element is 0, set its entire row and column to 0. Do it in place.

重点是空间复杂度限制为常数.

人家想法:

用 matrix 的第0行和第0列的元素分别记录所对应的行和列是否有0.

A[0][0]比较特殊,我们只让它记录第0行的情况,声明另一变量col0记录第0列的情况.

我的实现代码较长,但思路表达的相当清楚.人家也有贼短的代码,人家很牛逼.

算法分两大阶段(细分为 8 steps, 在程序注释中所示)

  1. 设置第0行,第0列以及col0,让它们正确表达所对应行、列的状态;
  2. 依据上述状态将对应行、列置0.

第一第二阶段均需注意顺序,如程序中注释所示.

第二阶段清0时,如下图:

^ 表示第0行或第0列的元素;
* 表示非0行,非0列元素
依据状态置0时,先清非第0行和第0列的元素,那就是 * 表示的那帮货!
再清第0行,最后依据col0清第0列. ^ ^ ^
^ * *
^ * *

有意思的是:col0展示了她的重要地位,她已跳出三界外,不在五行中.整个程序从她而起,最后又由她而终!

自己代码和注释:

\(O(n^2)\) time, \(O(1)\) space.

void setZeroes(vector<vector<int>>& A) {
// 程序分为8个step, 各step顺序不能颠倒
// 终极目的是避免记录状态的第0行和第0列被误写
int m = A.size(), n = A[0].size(), col0 = 1; // step1. 若第0列有0, col0 = 0
for (int i = 0; i < m; i++)
if (A[i][0] == 0) {
col0 = 0;
break;
} // step2. 若第0行有0, row0 = 0
for (int j = 0; j < n; j++)
if (A[0][j] == 0) {
A[0][0] = 0;
break;
} // step3. 依次检查除第0列以外的其他列j,若那列有0,则A[0][j]=0
for (int j = 1; j < n; j++)
for (int i = 0; i < m; i++)
if (A[i][j] == 0) {
A[0][j] = 0;
break;
} // step4. 依次检查除第0行以外的其他行i,若那行有0,则A[i][0]=0
for (int i = 1; i < m; i++)
for (int j = 0; j < n; j++)
if (A[i][j] == 0) {
A[i][0] = 0;
break;
} // 阶段性胜利:到此为止,我们把第0行与第0列,以及col0的 state 设置完成了
// 接下来,我们要根据上述状态,将对应元素设置为0 // step5. 依据第0列,修改第1~(m-1)行元素为0(注意:不改第0行,因为那里存着state)
for (int i = 1; i < m; i++)
if (A[i][0] == 0)
for (int j = 1; j < n; j++)
A[i][j] = 0; // step6. 依据第0行,修改第1~(n-1)列元素为0(注意:不改第0列,因为那里存着state)
for (int j = 1; j < n; j++)
if (A[0][j] == 0)
for (int i = 1; i < m; i++)
A[i][j] = 0; // step7. 按照A[0][0], 修改第0行元素为0
if (A[0][0] == 0)
for (int j = 1; j < n; j++)
A[0][j] = 0; // step8. 按照col0, 修改第0列元素为0, 再次强调, 以上次序不能调换
if (col0 == 0)
for (int i = 0; i < m; i++) //此时需将A[0][0]元素包含在内
A[i][0] = 0;
}

73. Set Matrix Zeroes(中等)的更多相关文章

  1. 【LeetCode】73. Set Matrix Zeroes (2 solutions)

    Set Matrix Zeroes Given a m x n matrix, if an element is 0, set its entire row and column to 0. Do i ...

  2. 73. Set Matrix Zeroes

    题目: Given a m x n matrix, if an element is 0, set its entire row and column to 0. Do it in place. Fo ...

  3. Leetcode#73 Set Matrix Zeroes

    原题地址 用矩形的第一行和第一列充当mask 代码: void setZeroes(vector<vector<int> > &matrix) { ].empty()) ...

  4. [LeetCode] 73. Set Matrix Zeroes 解题思路

    Given a m x n matrix, if an element is 0, set its entire row and column to 0. Do it in place. Follow ...

  5. leetcode[73] Set Matrix Zeroes 将矩阵置零

    给定一个矩阵,把零值所在的行和列都置为零.例如: 1 2 3 1 3 1 1 1 操作之后变为 1 3 0 0 0 1 1 方法1: 赋值另存一个m*n的矩阵,在原矩阵为零的值相应置新的矩阵行和列为零 ...

  6. LeetCode OJ 73. Set Matrix Zeroes

    Given a m x n matrix, if an element is 0, set its entire row and column to 0. Do it in place. click ...

  7. 【LeetCode】73. Set Matrix Zeroes

    题目: Given a m x n matrix, if an element is 0, set its entire row and column to 0. Do it in place. Fo ...

  8. 【一天一道LeetCode】#73. Set Matrix Zeroes

    一天一道LeetCode 本系列文章已全部上传至我的github,地址:ZeeCoder's Github 欢迎大家关注我的新浪微博,我的新浪微博 欢迎转载,转载请注明出处 (一)题目 Given a ...

  9. 73. Set Matrix Zeroes 把矩阵同一行列的元素都改成0

    [抄题]: Given a m x n matrix, if an element is 0, set its entire row and column to 0. Do it in-place. ...

随机推荐

  1. Spark-1.X编译构建及配置安装

    前提条件(环境要求) jdk版本:1.7+ scala版本:1.10.4+ maven版本:3.3.3+ 本博客中使用的软件版本 spark版本:spark-1.6.1.tar.gz(源码) jdk版 ...

  2. Hibernate(五):Hibernate配置文件及C3P0的用法

    配置文件可配项: 参考文档:hibernate-release-5.2.9.Final/documentation/userguide/html_single/Hibernate_User_Guide ...

  3. c#:ThreadPool实现并行分析,并实现线程同步结束

    背景: 一般情况下,经常会遇到一个单线程程序时执行对CPU,MEMORY,IO利用率上不来,且速度慢下问题:那么,怎么解决这些问题呢? 据我个人经验来说有以下两种方式: 1.并行.多线程(Parall ...

  4. .Net中Web增加加密狗管理

    由于业务中最近需要使用到加密狗,增加对Web代码的管控,所以需要进行加密狗使用的研究 首先,对于没有接触使用过加密狗的人需要有个大致的认识,加密狗分为 MasterDog, 1.下载加密狗的开发套件, ...

  5. else语句的搭配

    1.else语句搭配if 要么怎样,要么怎样 2.else语句搭配for和while 干完循环之后执行else,干不完或者break就不执行 3.else与异常处理 没有问题的话就执行else吧

  6. Thinkphp框架下连接两个及以上的数据库方法

    在我们的实际开发者,我们经常需要链接两个以上的数据库,方法跟简单 Thinkphp文档中也有介绍:点击查看 方法如下: 第一步:配置文件config.php <?php //默认数据库1 ret ...

  7. 那些年,曾踩过的Spark坑

    1.报错18/01/25 14:56:58 ERROR executor.CoarseGrainedExecutorBackend: Driver 127.0.0.1:37159 disassocia ...

  8. 浅谈轮播图(原生JavaScript实现)

    现在各种轮播图插件,玲琅满目,用起来也非常方便,通常只需要选择元素然后传入参数就可以了.但是,和授人以鱼不如授人以渔一样的道理,不管怎样最基本的轮播图原理还是应当掌握的.这样不仅有利于我们自己写出来满 ...

  9. php文件包含漏洞(input与filter)

    php://input php://input可以读取没有处理过的POST数据.相较于$HTTP_RAW_POST_DATA而言,它给内存带来的压力较小,并且不需要特殊的php.ini设置.php:/ ...

  10. codevs 1766 装果子

    提交地址:http://codevs.cn/problem/1766/ 1766 装果子  时间限制: 1 s  空间限制: 256000 KB  题目等级 : 黄金 Gold     题目描述 De ...