力扣(LeetCode)- 542. 01 矩阵

题目:

给定一个由 01 组成的矩阵 mat ,请输出一个 mat 矩阵中每一个格子对应位置元素到最近的 0 的距离的新矩阵。

两个相邻元素间的距离为 1

示例 1:

|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 0 |
| 1 | 1 | 1 |

复制代码
复制代码
输入:mat = [[0,0,0],[0,1,0],[1,1,1]]
输出:[[0,0,0],[0,1,0],[1,2,1]]

解答:javascript

主要思路就是,新建一个相同的数组 res,先将 0 位置填入,然后遍历所有 0 ,它位置的上下左右设为1,然后遍历所有 1 ,它位置的上下左右设为2,依次类推

javascript 复制代码
var updateMatrix = function(mat) {
    const res = []
    const visited = []
    for (let i = 0;i < mat.length;i++) {
      const r = []
      const v = []
      for (let j = 0;j < mat[0].length;j++) {
        if (mat[i][j]) {
          r.push(null)
          v.push(0)
        } else {
          r.push(0)
          v.push(1)
        }
      }
      res.push(r)
      visited.push(v)
    }
    dp(0, res, visited)
    return res
};

const dp = (n, res, visited) => {
  for (let i = 0;i < res.length;i++) {
    for (let j = 0;j < res[0].length;j++) {
      if (res[i][j] === n-1) {
        add(i, j, res, visited, n)
      }
    }
  }
  if (check(res)) {
    return
  }
  dp(n + 1, res, visited)
}

// 最近的元素距离0位置加1
const add = (i, j, res, visited, n) => {
  // left
  if (j - 1 >= 0) {
    set(i, j-1, res, visited, n)
  }
  // right
  if (j + 1 <= res[0].length - 1) {
    set(i, j+1, res, visited, n)
  }
  // up
  if (i - 1 >= 0) {
    set(i-1, j, res, visited, n)
  }
  // down
  if (i + 1 <= res.length - 1) {
    set(i+1, j, res, visited, n)
  }
}

const set = (i, j, res, visited, n) => {
  if (!visited[i][j]) {
    res[i][j] = n
    visited[i][j] = 1
  }
}

const check = (res) => {
  let flag = true
  
  for (let i = 0;i < res.length;i++) {
    for (let j = 0;j < res[0].length;j++) {
      if (res[i][j] === null) {
        flag = false
      }
    }
  }
  return flag
}
相关推荐
不知名的老吴19 小时前
经典算法题之行星碰撞
数据结构·算法
西安邮电大学19 小时前
有关数组的经典算法题
java·后端·其他·算法·面试
学Linux的语莫19 小时前
大模型微调数据集格式详解:Alpaca、ShareGPT、DPO、KTO、预训练数据怎么构建?
人工智能·算法·机器学习·微调格式
wayz1119 小时前
Momentum:UO(终极震荡指标)技术指标详解
算法·金融·数据分析·量化交易·特征工程
Boom_Shu19 小时前
浅拷贝与深拷贝
开发语言·c++·算法
触底反弹20 小时前
一文彻底搞懂 JavaScript 栈和队列(建议收藏)
javascript·算法·面试
WL学习笔记20 小时前
通讯录(顺序表实现)
c语言·数据结构·算法
AI_yangxi20 小时前
短视频矩阵系统供应商
大数据·人工智能·矩阵
Jerryhut20 小时前
opencv对齐算法及其应用
人工智能·opencv·算法
果丁智能20 小时前
智慧校园一卡通深度融合方案:基于超级SIM卡的手机碰一碰智能开锁技术落地实践
数据结构·人工智能·python·科技·算法·智能家居·信息与通信