题目
给定一个
m x n的矩阵,如果一个元素为 0 ,则将其所在行和列的所有元素都设为 0 。请使用 原地 算法。
解题思路
- 通过二层循环找出元素为0所在的行和列;
- 设置标志位记录当前行是否存在元素为0的,设置列表存储列为0的列;
- 在内循环结束后对存在元素为0的行,填充为0;
- 遍历列表,将列置为0;
代码展示
class Solution {
public void setZeroes(int[][] matrix) {
Set<Integer> row = new HashSet<>();
for (int i = 0; i < matrix.length; i++){
boolean status = false;
for (int j = 0; j < matrix[i].length; j++){
if(matrix[i][j] == 0){
status = true;
row.add(j);
}
}
if(status){
Arrays.fill(matrix[i], 0);
}
}
for (int num : row){
for (int i = 0; i < matrix.length; i++){
matrix[i][num] = 0;
}
}
}
}
文章描述了一种原地算法,用于解决给定矩阵中找到并置零0元素的问题,同时保持其他元素不变。算法通过查找0元素的位置,标记行和列,然后填充0并清除相关列来实现。

347

被折叠的 条评论
为什么被折叠?



