18.矩阵同行同列全置零

1.题目描述

2.解题思路

1)边遍历边置零(错误解法,因为边置零到后面遍历到前面置零得元素)

cpp 复制代码
 void setZeroes(vector<vector<int>>& matrix) {
        int row = matrix.size();//行数
        int col = matrix[0].size();//列数
        for(int i = 0;i<=row-1;i++){//遍历每一行
           for(int j = 0;j<=col-1;j++){//遍历该行每一个元素
              if(matrix[i][j]==0){
                for(int k = 0;k<=col-1;k++){
                    matrix[i][k]= 0;
                }
                for(int m = 0;m<=row-1;m++){
                    matrix[m][j]=0;
                }
              }
           }
        }
    }

2)先标记,再统一置零

cpp 复制代码
void setZeroes(vector<vector<int>>& matrix) {
        int row = matrix.size();//行数
        int col = matrix[0].size();//列数
        vector<int> tag_row(row,0);
        vector<int> tag_col(col,0);
        //put tag做标记
        for(int i = 0;i<=row-1;i++){//遍历每一行
           for(int j = 0;j<=col-1;j++){//遍历该行每一个元素
              if(matrix[i][j]==0){
                tag_row[i] = 1;
                tag_col[j] = 1;
              }
           }
        }
        //put zero置零
        for(int i = 0;i<=row-1;i++){//遍历每一行
           for(int j = 0;j<=col-1;j++){//遍历该行每一个元素
              if(tag_row[i]==1 || tag_col[j]==1){
                matrix[i][j]=0;
              }
           }
        }
    }
相关推荐
chao1898445 小时前
基于 SPEA2 的多目标优化算法 MATLAB 实现
开发语言·算法·matlab
沪漂阿龙5 小时前
AI大模型面试题:支持向量机是什么?间隔最大化、软间隔、核函数、LinearSVC 全面拆解
人工智能·算法·支持向量机
難釋懷5 小时前
Redis数据结构-Set结构
数据结构·redis·bootstrap
little~钰5 小时前
倍增算法和ST表
算法
知识领航员6 小时前
蘑兔AI音乐深度实测:功能拆解、实测表现与适用场景
java·c语言·c++·人工智能·python·算法·github
薛定e的猫咪6 小时前
因果推理研究方向综述笔记
人工智能·笔记·深度学习·算法
如何原谅奋力过但无声7 小时前
【灵神高频面试题合集06-08】反转链表、快慢指针(环形链表/重排链表)、前后指针(删除链表/链表去重)
数据结构·python·算法·leetcode·链表
平行侠7 小时前
037插入排序 - 整理扑克牌的算法
数据结构·算法
ECT-OS-JiuHuaShan8 小时前
彻底定理化:从量子纠缠到量子代谢
数据库·人工智能·学习·算法·生活·量子计算