【力扣hot100题】(116)矩阵置零

比较简单,但我只想出空间复杂度O(m+n)的方法。答案空间复杂度为O(1)的方法是将第一行第一列设为标记数组,标记哪些行列需要置零,还是很巧妙的。

cpp 复制代码
class Solution {
public:
    void setZeroes(vector<vector<int>>& matrix) {
        bool row=0;
        bool column=0;
        for(int i=0;i<matrix.size();i++) if(matrix[i][0]==0) row=1;
        for(int j=0;j<matrix[0].size();j++) if(matrix[0][j]==0) column=1;
        for(int i=0;i<matrix.size();i++){
            for(int j=0;j<matrix[0].size();j++){
                if(matrix[i][j]==0){
                    matrix[i][0]=0;
                    matrix[0][j]=0;
                }
            }
        }
        for(int i=1;i<matrix.size();i++){
            if(matrix[i][0]==0){
                for(int j=0;j<matrix[0].size();j++) matrix[i][j]=0;
            }
        }
        for(int i=1;i<matrix[0].size();i++){
            if(matrix[0][i]==0){
                for(int j=0;j<matrix.size();j++) matrix[j][i]=0;
            }
        }
        if(row==1) for(int i=0;i<matrix.size();i++) matrix[i][0]=0;
        if(column==1) for(int i=0;i<matrix[0].size();i++) matrix[0][i]=0;
    }
};
相关推荐
王老师青少年编程11 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:荷马史诗
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·荷马史诗
样例过了就是过了11 小时前
LeetCode热题100 最小路径和
c++·算法·leetcode·动态规划
Aaron158811 小时前
RFSOC+VU13P+GPU 在6G互联网中的技术应用
大数据·人工智能·算法·fpga开发·硬件工程·信息与通信·信号处理
风落无尘12 小时前
《智能重生:从垃圾堆到AI工程师》——第三章 矩阵与防线
人工智能·线性代数·矩阵
迷途之人不知返12 小时前
Stack & Queue
c++·算法
没文化的阿浩12 小时前
【数据结构】排序(2)——直接选择排序、堆排序
数据结构·算法·排序算法
ytttr87312 小时前
基于libusb的用户空间UVC相机库
算法
bybitq12 小时前
Reactor 模型 vs Proactor 模型:区别与代码示例
算法
jimy112 小时前
C 语言的 static 关键字作用
c语言·开发语言·算法
七颗糖很甜13 小时前
基于IRI-2016模型计算电子密度、TEC、foF2等参数的技术原理与代码实现
大数据·python·算法