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;
        }
      }
相关推荐
一枚前端小能手13 小时前
🔥 SSR服务端渲染实战技巧 - 从零到一构建高性能全栈应用
前端·javascript
Komorebi_999913 小时前
Vue3 provide/inject 详细组件关系说明
前端·javascript·vue.js
不一样的少年_13 小时前
【前端效率工具】:告别右键另存,不到 50 行代码一键批量下载网页图片
前端·javascript·浏览器
Asort13 小时前
JavaScript设计模式(八):组合模式(Composite)——构建灵活可扩展的树形对象结构
前端·javascript·设计模式
木觞清14 小时前
喜马拉雅音频链接逆向实战
开发语言·前端·javascript
一枚前端小能手14 小时前
「周更第6期」实用JS库推荐:InversifyJS
前端·javascript
叉歪14 小时前
纯前端函数,一个拖拽移动、调整大小、旋转、缩放的工具库
javascript
Hilaku14 小时前
"事件委托"这个老古董,在现代React/Vue里还有用武之地吗?
前端·javascript·vue.js
向葭奔赴♡14 小时前
前端框架学习指南:提升开发效率
前端·javascript·vue.js
小高00714 小时前
🔥🔥🔥Vue 3.5 核弹级小补丁:useTemplateRef 让 ref 一夜失业?
前端·javascript·vue.js