Leetcode 73 矩阵置0

java 复制代码
class Solution {
    //1.用矩阵的第一行和第一列来标记该行或该列是否应该为0,但是这样的话忽视了第一行或第一列为0的情况
    //2.用标记row0和column0来标记第一行或第一列是否该为0
    public void setZeroes(int[][] matrix) {
        int n = matrix.length;
        int m = matrix[0].length;
        boolean row0 = false;
        boolean column0 = false;
        for(int i = 0; i < n; i++){
            if(matrix[i][0] == 0){
                column0 = true;
            }

        }
        for(int j = 0; j < m; j++){
            if(matrix[0][j] == 0){
                row0 = true;

            }
        }
        for(int i = 1; i < n; i++){
            for(int j = 1; j < m; j++){
                if(matrix[i][j] == 0){
                    matrix[0][j] = 0;
                    matrix[i][0] = 0;
                }
            }
        }
        for(int i = 1; i < n; i++){
            for(int j = 1; j < m; j++){
                if(matrix[i][0] == 0 || matrix[0][j] == 0) matrix[i][j] = 0;
            }
        }
        if(row0){
            for(int i = 0; i < m; i++) matrix[0][i] = 0;
        }
        if(column0){
            for(int i = 0; i < n; i++) matrix[i][0] = 0;
        }
    }
}
相关推荐
kyle~5 分钟前
算法---贪心算法(Greedy Algorithm)
算法·贪心算法
fashion 道格9 分钟前
C 语言数组拼接:从基础实现到细节优化
算法
头发还没掉光光33 分钟前
Linux多线程之自旋锁与读写锁
linux·运维·算法
fashion 道格34 分钟前
C 语言希尔排序:原理、实现与性能深度解析
数据结构·算法·排序算法
初夏睡觉1 小时前
P1048 [NOIP 2005 普及组] 采药
数据结构·c++·算法
小欣加油1 小时前
leetcode 1513 仅含1的子串数
c++·算法·leetcode·职场和发展
树在风中摇曳1 小时前
【C语言预处理器全解析】宏、条件编译、字符串化、拼接
c语言·算法
CodeWizard~1 小时前
P7149 [USACO20DEC] Rectangular Pasture S题解
算法
YaraMemo2 小时前
对称/Hermitian矩阵相关记号
线性代数·5g·矩阵·信息与通信
fashion 道格2 小时前
用 C 语言破解汉诺塔难题:递归思想的实战演练
c语言·算法