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 == matrix0.length

1 <= m, n <= 200
− 2 31 < = m a t r i x i j < = 2 31 − 1 -2^{31} <= matrixij <= 2^{31} - 1 −231<=matrixij<=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;
				}
			}	
		} 
    }
};
相关推荐
徐小夕16 小时前
万字长文!千万级文档 RAG 知识库系统落地实践
前端·算法·github
akunkuntaimei17 小时前
2026年高考数学各省真题及答案(完整版)
算法·高考
Hello:CodeWorld17 小时前
C 风格变参 vs C++ 变参模板:核心区别与选型指南
c语言·c++·算法
8Qi818 小时前
LeetCode 516:最长回文子序列
算法·leetcode·职场和发展·动态规划
youngerwang20 小时前
【从搬运工到协处理器:网卡芯片架构、算法、验证与边缘演进深度剖析】
网络·算法·架构·芯片
KaMeidebaby20 小时前
卡梅德生物技术快报|纯化重组蛋白实操详解
人工智能·python·tcp/ip·算法·机器学习
dingzd9521 小时前
跨境社媒运营越到后面 越比拼账号的表达稳定性
大数据·人工智能·矩阵·内容营销
手写码匠21 小时前
从零实现 Prompt 工程引擎:结构化提示、自动优化与多轮自省体系
人工智能·深度学习·算法·aigc
无限码力21 小时前
阿里算法岗 0530笔试真题 - 多约束条件下的元素匹配统计
算法·阿里笔试真题·阿里机试真题·阿里算法岗笔试
lqqjuly21 小时前
MLA — 多头潜在注意力深度解析
深度学习·神经网络·算法