【力扣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;
    }
};
相关推荐
永远都不秃头的程序员(互关)21 小时前
【决策树深度探索(一)】从零搭建:机器学习的“智慧之树”——决策树分类算法!
算法·决策树·机器学习
程序员-King.21 小时前
day161—动态规划—最长递增子序列(LeetCode-300)
算法·leetcode·深度优先·动态规划·递归
西柚小萌新21 小时前
【计算机视觉CV:目标检测】--3.算法原理(SPPNet、Fast R-CNN、Faster R-CNN)
算法·目标检测·计算机视觉
高频交易dragon1 天前
Hawkes LOB Market从论文到生产
人工智能·算法·金融
_OP_CHEN1 天前
【算法基础篇】(五十)扩展中国剩余定理(EXCRT)深度精讲:突破模数互质限制
c++·算法·蓝桥杯·数论·同余方程·扩展欧几里得算法·acm/icpc
福楠1 天前
C++ STL | set、multiset
c语言·开发语言·数据结构·c++·算法
enfpZZ小狗1 天前
基于C++的反射机制探索
开发语言·c++·算法
炽烈小老头1 天前
【每天学习一点算法 2026/01/22】杨辉三角
学习·算法
MicroTech20251 天前
微算法科技(NASDAQ :MLGO)量子安全区块链:PQ-DPoL与Falcon签名的双重防御体系
科技·算法·安全
努力也学不会java1 天前
【Spring Cloud】 服务注册/服务发现
人工智能·后端·算法·spring·spring cloud·容器·服务发现