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

企业网站建设排名推荐网站缓存优化怎么做

企业网站建设排名推荐,网站缓存优化怎么做,wordpress怎么建导航,相城区住房建设局网站题目描述: 给定一个由 0 和 1 组成的矩阵 mat ,请输出一个大小相同的矩阵,其中每一个格子是 mat 中对应位置元素到最近的 0 的距离。 两个相邻元素间的距离为 1 。 示例 1: 输入:mat [[0,0,0],[0,1,0],[0,0,0]] 输出…

题目描述:

给定一个由 0 和 1 组成的矩阵 mat ,请输出一个大小相同的矩阵,其中每一个格子是 mat 中对应位置元素到最近的 0 的距离。

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

示例 1:

输入:mat = [[0,0,0],[0,1,0],[0,0,0]]
输出:[[0,0,0],[0,1,0],[0,0,0]]

示例 2:

输入:mat = [[0,0,0],[0,1,0],[1,1,1]]
输出:[[0,0,0],[0,1,0],[1,2,1]]

提示:

  • m == mat.length
  • n == mat[i].length
  • 1 <= m, n <= 104
  • 1 <= m * n <= 104
  • mat[i][j] is either 0 or 1.
  • mat 中至少有一个 

题目链接:

. - 力扣(LeetCode)

解题主要思路:

这道题明显是bfs的一种,但是跟之前刷到的 "最短路径" 类题目又不太一样。准确的来说,之前刷到的 "最短路径" 类题目是端到端的bfs,而这道题是多个端到一个端的bfs,即多源bfs。如果按照之前的 "最短路径" 的方式来硬解的话,遍历原数组的时间复杂度是On,遍历原数组的时候进行bfs,时间复杂度是On2,这样下来时间复杂度来到了惊人的On的立方。

其实,我们可以换个思路,既然是多个端到一个端,那我们就反着来,从一个端一层一层往外扩到多个端。就以这题为例,多个端指的是1,一个端指的是0,我们就反着来,从0的位置一层一层往外扩。

解题代码:

class Solution {
public:int dx[4]{0, 0, 1, -1};int dy[4]{1, -1, 0, 0};vector<vector<int>> updateMatrix(vector<vector<int>>& mat) {int m = mat.size(), n = mat[0].size();vector<vector<int>> ret(m, vector<int>(n, -1));queue<pair<int, int>> que;// 将0的坐标加入到队列中for (int i = 0; i < m; ++i) for (int j = 0; j < n; ++j) if (mat[i][j] == 0) {que.push(make_pair(i, j));ret[i][j] = 0;}// ret[x][y] == -1 原数组该下标元素为1且未遍历(外扩到)// ret[x][y] != -1 原数组该下标元素为0 or 该位置为1且已遍历// 一层一层往外扩while (que.size()) {auto [a, b] = que.front(); que.pop();for (int i = 0; i < 4; ++i) {int x = a + dx[i], y = b + dy[i];if (x >= 0 && x < m && y >= 0 && y < n && ret[x][y] == -1) {ret[x][y] = ret[a][b] + 1;que.push(make_pair(x, y));}}}return ret;}};

http://www.yayakq.cn/news/11556/

相关文章:

  • 网站建设方案样本成全视频观看技巧和方法
  • 德阳企业网站建设怎样用电脑和网訨自己做网站
  • 网站建设移交确认书腾讯云域名续费
  • 电商网站开发哪里好seo刷词工具在线
  • 做网站按页面收费wordpress跑一亿数据
  • 郑州 (网站建设苏州网址制作公司
  • 阿里自助建站开源社区源码
  • 引流网站怎么做做网站一年费用
  • 怎么看网站空间电商seo什么意思
  • 企业网络推广网站建设一般做企业网站需要什么
  • 简单响应式网站优化英文
  • 电子商务网站有哪些和网址手机网站适应屏幕
  • 网站被主流搜索引擎收录的网页数量wordpress极客式主题
  • 做粘土的网站logo设计网站平台
  • 做药材生意的网站wordpress分类目录链接
  • 温州建设银行支行网站优秀的ui设计案例分析
  • 宁波网站建设服务商在网站建设中注意的要点
  • 蒙城做网站想让一个网站上线需要怎么做
  • 网站闭站保护为什么网站突然打不开
  • 会建网站的人企业邮箱格式怎么注册
  • 投资建设网站wordpress 采集
  • 搜狗搜索引擎优化论文泉州seo技术
  • 免费医院网站源码免费产品推广网站
  • 买购网官方网站手机pc微信三合一网站
  • psd设计网站模板门户网站建设厂商名录
  • 网站创意wordpress标签生成器
  • 毕设做网站类型微信彩票网站网站建设
  • 我国网站建设现状上海公司注册联贝财务优势
  • 网站开发前端兼职网站建设需要会一些啥
  • 购物网站开发面试科技感办公室设计