5-数组-矩阵置零

这是数组的第5篇算法,力扣链接

给定一个 mxn 的矩阵,如果一个元素为 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]]

看到这道题的第一反应就是打表,两次遍历,一次记录清零的行列,最后再遍历清零。

Go 复制代码
func setZeroes(matrix [][]int) {
	rows, cols := make([]bool, len(matrix)), make([]bool, len(matrix[0]))
	for ri, row := range matrix {
		for ci, col := range row {
			if col == 0 {
				rows[ri] = true
				cols[ci] = true
			}
		}
	}
	for ri, row := range matrix {
		for ci, _ := range row {
			if rows[ri] || cols[ci] {
				matrix[ri][ci] = 0
			}
		}
	}
}

这里有多种解法,核心逻辑都差不多,只不过标记的方法不同。

这里延伸出一种特殊的标注逻辑,我们将每一行/列的信息同步到第一行/列中,这样就不会额外占用空间了。值得注意的是,第一列是否需要清零需要额外标注。

Go 复制代码
func setZeroes(matrix [][]int) {
	col0 := false
	for _, row := range matrix {
		if row[0] == 0 {
			col0 = true
		}
		for j := 1; j < len(matrix[0]); j++ {
			if row[j] == 0 {
				row[0] = 0
				matrix[0][j] = 0
			}
		}
	}
	for i := len(matrix) - 1; i >= 0; i-- {
		for j := 1; j < len(matrix[0]); j++ {
			if matrix[i][0] == 0 || matrix[0][j] == 0 {
				matrix[i][j] = 0
			}
		}
		if col0 {
			matrix[i][0] = 0
		}
	}
}
相关推荐
菜鸟233号12 小时前
力扣213 打家劫舍II java实现
java·数据结构·算法·leetcode
方便面不加香菜12 小时前
数据结构--栈和队列
c语言·数据结构
狐5712 小时前
2026-01-18-LeetCode刷题笔记-1895-最大的幻方
笔记·算法·leetcode
Q741_14713 小时前
C++ 队列 宽度优先搜索 BFS 力扣 662. 二叉树最大宽度 每日一题
c++·算法·leetcode·bfs·宽度优先
Pluchon13 小时前
硅基计划4.0 算法 动态规划进阶
java·数据结构·算法·动态规划
wzf@robotics_notes13 小时前
振动控制提升 3D 打印机器性能
嵌入式硬件·算法·机器人
机器学习之心14 小时前
MATLAB基于多指标定量测定联合PCA、OPLS-DA、FA及熵权TOPSIS模型的等级预测
人工智能·算法·matlab·opls-da
Loo国昌14 小时前
【LangChain1.0】第八阶段:文档处理工程(LangChain篇)
人工智能·后端·算法·语言模型·架构·langchain
xb113214 小时前
Winforms实战项目:运动控制界面原型
算法
MicroTech202514 小时前
微算法科技(NASDAQ :MLGO)量子安全哈希(QSHA),增强量子时代的区块链安全保障
科技·算法·安全