73.矩阵置零

给定一个 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]]

思路:找位置为0的,然后把所在的行和列都置为0(把这些0给标记下,遍历到这些位置上的0不用把同行列上的数值为零)

javascript 复制代码
let flag = new Array();
        var setZeroes = function (matrix) {
        for (let i = 0; i < matrix.length; i++) {
          flag[i] = new Array();
          for (let j = 0; j < matrix[i].length; j++) {
            flag[i][j] = 0;
          }
        }
        for (let i = 0; i < matrix.length; i++) {
          for (let j = 0; j < matrix[i].length; j++) {
            if (matrix[i][j] == 0 && flag[i][j] == 0) {
              dfs(i, j, matrix);
            }
          }
        }
      };
      function dfs(row, column, matrix) {
        for (let i = 0; i < matrix.length; i++) {
          if (matrix[i][column] == 0) continue; //本身就为零
          flag[i][column] = 1;
          matrix[i][column] = 0;
        }
        for (let i = 0; i < matrix[row].length; i++) {
          if (matrix[row][i] == 0) continue; //本身就为零
          flag[row][i] = 1;
          matrix[row][i] = 0;
        }
      }
相关推荐
zhoxier2 小时前
elementui el-select 获取value和label 以及 对象的方法
javascript·vue.js·elementui
是小狐狸呀2 小时前
elementUI-表单-下拉框数据选中后,视图不更新
前端·javascript·elementui
快去睡觉~3 小时前
力扣73:矩阵置零
算法·leetcode·矩阵
IT码农-爱吃辣条6 小时前
Three.js 初级教程大全
开发语言·javascript·three.js
烛阴6 小时前
告别繁琐的类型注解:TypeScript 类型推断完全指南
前端·javascript·typescript
gnip6 小时前
工程项目中.env 文件原理
前端·javascript
JohnYan7 小时前
工作笔记 - CentOS7环境运行Bun应用
javascript·后端·容器
云手机掌柜8 小时前
Tumblr长文运营:亚矩阵云手机助力多账号轮询与关键词布局系统
大数据·服务器·tcp/ip·矩阵·流量运营·虚幻·云手机
tt5555555555558 小时前
字符串与算法题详解:最长回文子串、IP 地址转换、字符串排序、蛇形矩阵与字符串加密
c++·算法·矩阵
东风西巷9 小时前
Rubick:基于Electron的开源桌面效率工具箱
前端·javascript·electron·软件需求