LeetCode热题100 矩阵置零

题目描述

给定一个 m x n 的矩阵,如果一个元素为 0 ,则将其所在行和列的所有元素都设为 0 。请使用 原地 算法

示例 1:

输入: matrix = [[1,1,1],[1,0,1],[1,1,1]]
输出: [[1,0,1],[0,0,0],[1,0,1]]

示例 2:

输入: matrix = [[0,1,2,0],[3,4,5,2],[1,3,1,5]]
输出: [[0,0,0,0],[0,4,5,0],[0,3,1,0]]

提示:

m == matrix.length

n == matrix[0].length

1 <= m, n <= 200
− 2 31 < = m a t r i x [ i ] [ j ] < = 2 31 − 1 -2^{31} <= matrix[i][j] <= 2^{31} - 1 −231<=matrix[i][j]<=231−1

思路

1 把最后一行和最后一列作为标记 ,某个位置出现0,就把所在位置的最后一行和最后一列置为0。

2 最后一行和最后一列提前处理并用两个bool变量标记

3 最后进行遍历判断是否有标记即可

代码

cpp 复制代码
class Solution {
public:
    void setZeroes(vector<vector<int>>& matrix) {
        bool row = false, col = false;
        int n = matrix.size();
        int m = matrix[0].size();
        
        // 进行标记 
        for(int i = 0; i < n; ++i)
        {
        	// 最后一列特殊标记 
        	if(matrix[i][m - 1] == 0)col = true; 
        	for(int j = 0; j < m; ++j)
        	{
        		// 最后一行特殊标记
				if(i == 0 && matrix[n - 1][j] == 0)row = true;
				// 除了最后一行和最后一列之外的标记 
				if(matrix[i][j] == 0 && i != n - 1 && j != m - 1) matrix[i][m -1] = matrix[n - 1][j] = 0;		 
			}
		}
		// 获取结果
		for(int i = 0; i < n; ++i)
		{
			for(int j = 0; j < m; ++j)
			{
                // 最后一行&&最后一列特殊处理
				if(i == n - 1 && j == m - 1)
				{
					if(row == true || col == true) matrix[i][j] = 0;
				}
				// 最后一行特殊处理 
				else if(i == n - 1)
				{
					if(row == true) matrix[i][j] = 0;
				}	
				// 最后一列特殊处理
				else if(j == m - 1)
				{
					if(col == true) matrix[i][j] = 0;
				} 
				else
				{
					if(matrix[n - 1][j] == 0 || matrix[i][m - 1] == 0) matrix[i][j] = 0;
				}
			}	
		} 
    }
};
相关推荐
AI科技星5 分钟前
ELN 升级:π 级数自动生成器全域数理架构
大数据·人工智能·python·算法·金融
强盛机器学习~9 分钟前
2026年SCI一区新算法-傅里叶变换优化算法(FTO)-公式原理详解与性能测评 Matlab代码免费获取
算法·matlab·进化计算·群体智能·傅里叶变换·元启发式算法
王老师青少年编程13 分钟前
csp信奥赛C++高频考点专项训练之贪心算法 --【跳跃与过河问题】:过河问题
c++·算法·贪心·csp·信奥赛·跳跃与过河问题·过河问题
沉默-_-1 小时前
备战蓝桥杯-哈希
c++·学习·算法·蓝桥杯·哈希算法
拼好饭和她皆失1 小时前
基础算法--写给算法小白的模板指南:快速掌握核心代码,蓝桥杯必备模板
算法
吞下星星的少年·-·1 小时前
rotate函数应用模板
算法
AI科技星1 小时前
人类首张【全域数学公理体系】黑洞内部结构图—基于「0-1-∞」三元本源的全维深度解析
人工智能·算法·机器学习·数学建模·数据挖掘·量子计算
paeamecium1 小时前
【PAT甲级真题】- Recover the Smallest Number (30)
数据结构·算法·pat考试·pat
Dillon Dong1 小时前
【风电控制】变流器转矩控制回路深度解析:从指令生成到闭环控制
算法·变流器·风电控制
玛丽莲茼蒿1 小时前
Leetcode hot100 在排序数组中查找元素的第一个和最后一个位置【中等】
数据结构·算法