当前位置: 首页 > news >正文

矩阵-矩阵置零

矩阵置零

给定一个 m x n 的矩阵,如果一个元素为 0 ,则将其所在行和列的所有元素都设为
 0 。请使用 原地 算法。
 在计算机科学中,一个原地算法(in-place algorithm)是一种使用小的,固定数
 量的额外之空间来转换资料的算法。当算法执行时,输入的资料通常会被要输出的部
 分覆盖掉。不是原地算法有时候称为非原地(not-in-place)或不得其所
 (out-of-place)。

在这里插入图片描述
输入:二维数组
输出:二维数组
思路

方法一:使用两个标记数组
两个标记数组分别记录每一行和每一列是否有零出现,如果出现,则将对应的标记数组置为true,最后再次遍历数组,用标记数组更新原数组即可

class Solution {
    public void setZeroes(int[][] matrix) {
        //用变量定义数组的行和列的长度,方便写代码
        int m = matrix.length;
        int n = matrix[0].length;
        //定义标记数组
        boolean [] row = new boolean[m];
        boolean [] col = new boolean[n];
        //对标记数组进行赋值
        for(int i = 0;i < m;i++){
            for(int j = 0;j < n;j++){
                if(matrix[i][j] == 0){
                    row[i] = col[j] = true;
                }
            }
        }
        //再次遍历,只要有一个标记为true,则置为0
        for(int i = 0;i < m;i++){
            for(int j = 0;j < n;j++){
                if(row[i] || col[j]){
                    matrix[i][j] = 0;
                }
            }
        }
    }
}

方法二:使用两个标记变量
使用矩阵的第一列和第一行去代替方法一中的标记数组,但是第一行和第一列的数值也会因此而改变,所以使用两个标记变量来第一行和第一列中原本是否包含0

class Solution {
    public void setZeroes(int[][] matrix) {
        //用变量定义数组的行和列的长度,方便写代码
        int m = matrix.length;
        int n = matrix[0].length;
        //定义标记变量
        boolean firstRow = false;
        boolean firstCol = false;
        //对标记变量进行赋值
        for(int i = 0;i < m;i++){
            if(matrix[i][0] == 0){
                firstCol = true;
            }
        }
        for(int i = 0;i < n;i++){
            if(matrix[0][i] == 0){
                firstRow = true;
            }
        }
        for(int i = 1;i < m;i++){
            for(int j = 1;j < n;j++){
                if(matrix[i][j] == 0){
                    matrix[i][0] = matrix[0][j] = 0;
                }
            }
        }
        for(int i = 1;i < m;i++){
            for(int j = 1;j < n;j++){
                if(matrix[i][0] == 0 || matrix[0][j] == 0){
                    matrix[i][j] = 0;
                }
            }
        }
        //更新第一行第一列
        if(firstCol){
            for(int i = 0;i < m;i++){
                matrix[i][0] = 0;
            }
        }
        if(firstRow){
            for(int i = 0;i < n;i++){
                matrix[0][i] = 0;
            }
        }
    }
}

方法三:使用一个标记变量
第一列的第一个元素即可以标记第一行是否出现0。但为了防止每一列的第一个元素被提前更新,我们需要从最后一行开始,倒序地处理矩阵元素。

class Solution {
    public void setZeroes(int[][] matrix) {
        //用变量定义数组的行和列的长度,方便写代码
        int m = matrix.length;
        int n = matrix[0].length;
        //定义标记变量
        boolean firstColAndRow = false;
        //对标记变量进行赋值
        for(int i = 0; i < m; i++){
            if(matrix[i][0] == 0){
                firstColAndRow = true;
            }
            for(int j = 1; j < n; j++){
                if(matrix[i][j] == 0){
                    matrix[i][0] = matrix[0][j] = 0;
                }
            }
        }
        //倒序
        for(int i = m - 1; i >= 0; i--){
            for(int j = 1; j < n; j++){
                if(matrix[i][0] == 0 || matrix[0][j] == 0){
                    matrix[i][j] = 0;
                }
            }
            if(firstColAndRow){
                matrix[i][0] = 0;
            }
        }
        
    }
}

相关文章:

  • 并查集算法篇上期:并查集原理及实现
  • FreeSWITCH Alpine 安装
  • 【股票数据API接口35】如何获取股票当天分价成交占比数据之Python、Java等多种主流语言实例代码演示通过股票数据接口获取数据
  • 亚马逊的API服务怎么使用?
  • 力扣每日一题【算法学习day.131】
  • 【Erdas实验教程】009:非监督分类及分类后评价
  • TypeScript - 属性修饰符
  • Python 单例模式笔记
  • RFID测温技术:电力设备安全监测的新利器
  • 深入解析Textual库:打造现代化的终端用户界面(TUI)
  • 【Python爬虫(37)】解锁分布式爬虫:原理与架构全解析
  • 深入理解 Kafka 主题分区机制
  • JUC并发—9.并发安全集合四
  • Html5学习教程,从入门到精通,HTML5 元素语法知识点及案例代码(2)
  • 普通人使用生成式语言模型的几个阶段
  • thinkphp 框架 如何让某个接口不需要登录权限
  • Java中字符串按照反斜杠切分报错
  • 正则表达式常用记录
  • MyBatis在Spring配置文件中注册
  • Javascript网页设计案例:通过PDFLib实现一款PDF分割工具,分割方式自定义-完整源代码,开箱即用
  • 成人学历提升/seo信息优化
  • 学做PPT报告的网站/seo研究协会网
  • zblog可以做视频网站吗/优化网站排名的方法
  • 王野天 女演员/金阊seo网站优化软件
  • wordpress文章页幻灯片/企业整站优化
  • 做房地产公司网站的费用/seo分析工具