【集合】LeetCode 73. 矩阵置零
题目链接
思路1
遍历矩阵,分别使用集合 row
和 column
记录值为0的行和列。最后将 row
和 column
所记录的行和列置为零。
空间复杂度:
代码1
class Solution {
public void setZeroes(int[][] matrix) {
Set<Integer> row = new HashSet<>();
Set<Integer> column = new HashSet<>();
for(int i = 0; i < matrix.length; i++){
for(int j = 0; j < matrix[i].length; j++){
if(matrix[i][j] == 0){
row.add(i);
column.add(j);
}
}
}
for(int i : row){
Arrays.fill(matrix[i], 0);
}
for(int j : column){
for(int i = 0; i < matrix.length; i++){
matrix[i][j] = 0;
}
}
}
}
思路2
该题还可以让矩阵的首行和首列成为标记变量,如果该行或者该列有0出现,则将行首或列首元素置为0。为了区首行和首列是否本来就有0,使用两个 boolean
类型变量分别记录首行和首列的初始状态。如果有0则为 true
。
空间复杂度:
代码2
class Solution{
public void setZeroes(int[][] matrix){
boolean firstRowHasZero = false;
boolean fistColHasZero = false;
for(int i = 0; i < matrix.length; i++){
for(int j = 0; j < matrix[0].length; j++){
if(matrix[i][j] == 0){
if(i == 0){
firstRowHasZero = true;
}
if(j == 0){
fistColHasZero = true;
}
matrix[i][0] = 0;
matrix[0][j] = 0;
}
}
}
for(int i = 1; i < matrix.length; i++){
for(int j = 1; j < matrix[0].length; j++){
if(matrix[i][0] == 0 || matrix[0][j] == 0){
matrix[i][j] = 0;
}
}
}
if(firstRowHasZero){
for(int i = 0; i < matrix[0].length; i++){
matrix[0][i] = 0;
}
}
if(fistColHasZero){
for(int i = 0; i < matrix.length; i++){
matrix[i][0] = 0;
}
}
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!