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

公司网站首页的图片怎么做廊坊住房和城乡建设厅网站

公司网站首页的图片怎么做,廊坊住房和城乡建设厅网站,知更鸟wordpress设置注册,互联网营销师题库及答案文章目录 前言那么什么是单源最短路 / 多源最短路呢#xff1f;如何解决此类题#xff1f;解法一解法二对于解法二#xff0c;如何编写代码#xff1f; 算法题542.01矩阵1020.飞地的数量1765.地图中的最高点1162.地图分析 前言 此前我们对 单源最短路 问题进行的讲解… 文章目录 前言那么什么是单源最短路 / 多源最短路呢如何解决此类题解法一解法二对于解法二如何编写代码 算法题542.01矩阵1020.飞地的数量1765.地图中的最高点1162.地图分析 前言 此前我们对 单源最短路 问题进行的讲解 使用bfs算法解决单源最短路问题 那么什么是单源最短路 / 多源最短路呢 画图来说单源最短路问题即为 而对于多源最短路问题: 如何解决此类题 自然是 利用BFS算法解决下面提出解法 解法一 解法二 当我们将所有的源点作为一个源点来进行解题时问题又变成了单源最短路问题而为什么可以认为这种解法是正确的呢? 感性的理解 对于上图的ABC三点显然A点到目标点的距离更远当我们将其作为一个点时A点就会被直接排除此时该特殊源点实际上就是最近的源点的合并。 对于解法二如何编写代码 我们对于 单源最短路 问题的bfs解法为 将起始点加入到队列中再进行一层一层的扩展 自然对于 多源最短路 的bfs解法为 将所有的起始点加入到队列中再进行一层一层的扩展 算法题 542.01矩阵 思路 题意分析题目要求返回一个数组该数组的每一位都是矩阵中当前位置到最近的0的距离。这个数组我们叫做dist数组下面多道题都会用上解法一 对每个位置都进行扩展 解法二 bfs 正难则反 dist数组 正难则反将思维逆转我们以0作为起点对矩阵进行扩容dist数组也是结果数组开始初始化为-1对于dist[i][j] dist[i][j] -1未被检索过dist[i][j] ! -1该位置到0的最短距离 将矩阵的所有起始点0的位置加入矩阵根据下图的思路每次对队列中的元素进行扩展 代码 class Solution { public:int dx[4] {0, 0, -1, 1};int dy[4] {-1, 1, 0 ,0};vectorvectorint updateMatrix(vectorvectorint mat) {int m mat.size(), n mat[0].size();vectorvectorint dist(m, vectorint(n, -1)); // 将dist数组元素初始化为-1(未检索的状态)queuepairint, int q;// 正难则反以矩阵中的0作为起点进行扩展// 将所有起始点入队for(int i 0; i m; i)for(int j 0; j n; j)if(mat[i][j] 0){q.push({i, j});dist[i][j] 0;}// 对队列中的元素进行拓展while(q.size()){auto [a, b] q.front(); q.pop();for(int i 0; i 4; i){int x dx[i] a, y dy[i] b;if((x 0 x m) (y 0 y n) dist[x][y] -1){dist[x][y] dist[a][b] 1;q.push({x, y});}}}return dist;} };1020.飞地的数量 思路 题意分析题目要求返回无法离开水域的陆地单元格个数即在边界内且被水域完全包裹的单元格。解法 bfs 正难则反 正难则反我们以四边的1为起点向内扩展多源bfs将四边的1作为起点入队将相连接的陆地单元格标记最后遍历visited数组统计结果 代码 class Solution { public:int dx[4] {0, 0, -1, 1};int dy[4] {-1, 1, 0, 0};int numEnclaves(vectorvectorint grid) {int m grid.size(), n grid[0].size();// 将visited数组元素初始化为0vectorvectorbool visited(m, vectorbool(n, false));queuepairint, int q;// 正难则反以边界的1为起始点进行bfs// 1. 找到边界1并扩展for(int i 0; i m; i)for(int j 0; j n; j)if(((i 0 || i m-1) || (j 0 || j n-1)) grid[i][j] 1){q.push({i, j});visited[i][j] true;}// 2. 多源bfswhile(q.size()){auto [a, b] q.front(); q.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) !visited[x][y] grid[x][y]){q.push({x, y});visited[x][y] true;}}}// 3. 提取结果int ret 0;for(int i 0; i m; i)for(int j 0; j n; j)if(!visited[i][j] grid[i][j])ret;return ret;} };1765.地图中的最高点 思路 题意分析题目给出一个矩阵1为水域0为陆地要求我们自行安排陆地高度使矩阵的最高高度最大相邻单元格高度差 1解法 bfs dist数组 思路 首先创建dist数组原理与第一题01矩阵一样将矩阵中所有水域的位置在dist中初始化为0并插入到队列中。由于要求矩阵的最高高度最大我们在设计高度时自然要将高度差都设为最大值即1随后进行多源bfs的操作综上我们发现这道题理清思路后代码方面和“01矩阵”完全一致 代码 class Solution { public:int dx[4] {0, 0, -1, 1};int dy[4] {-1, 1, 0, 0};vectorvectorint highestPeak(vectorvectorint isWater) {// 思路同 “10矩阵”int m isWater.size(), n isWater[0].size();vectorvectorint dist(m, vectorint(n, -1));queuepairint, int q;// 1.对水域进行扩展for(int i 0; i m; i)for(int j 0; j n; j)if(isWater[i][j] 1) // 1是水域{q.push({i, j});dist[i][j] 0;}// 2.while(q.size()){auto [a, b] q.front(); q.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) dist[x][y] -1){q.push({x, y});dist[x][y] dist[a][b] 1;}}}return dist;} };1162.地图分析 思路 题意分析题目要求找到离陆地最远的海洋单元格的曼哈顿距离 曼哈顿距离 简单解释为 解法思路 bfs 正难则反 dist数组 正难则反题目要求找海洋到陆地的最大距离我们以陆地单元格作为起始点向内扩展同样的思路我们首先遍历数组将陆地单元格位置存入到队列中并标记dist的位置后执行多源bfs的代码思路即可 代码 class Solution { public:int dx[4] {0, 0, -1, 1};int dy[4] {-1, 1, 0, 0};int maxDistance(vectorvectorint grid) {int m grid.size(), n grid[0].size();// 正难则反以1为起点向内扩展并标记vectorvectorint dist(m, vectorint(n, -1));queuepairint, int q;// 1. 根据单元格1向内扩展for(int i 0; i m; i)for(int j 0; j n; j)if(grid[i][j] 1){q.push({i, j});dist[i][j] 0;}// 2. 多源bfsint ret -1; // 统计结果while(q.size()){auto [a, b] q.front(); q.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) dist[x][y] -1){q.push({x, y});dist[x][y] dist[a][b] 1;ret max(ret, dist[x][y]);}}}return ret;} };
http://www.zqtcl.cn/news/959265/

相关文章:

  • 没有网站如何做落地页城市门户网站建设
  • 网易梦幻西游手游官方网站下载制作网站谁家做的好
  • 北京网站制作外包如何在易语言上做网站
  • 中国的网站做欧美风广告设计是干什么的
  • 做酱菜网站做网站什么是解析什么是跳转
  • 西安企业网站备案一般得多少天网站建设公司2018
  • 网站建设安全方案许昌正规网站优化公司
  • 厦门 外贸网站一般什么企业需要建站
  • 代理注册公司需要什么条件网络推广优化服务
  • 做淘宝客网站需要备案吗物流企业
  • 珠海正规网站制作系统东莞建站多少钱
  • 做网站框架图哪个在线网站好用中铁三局招聘官网
  • wordpress百度站内搜索wordpress 修改用户名
  • 网络企业网站建设方案做网站大概需要多少费用
  • 网站301是什么意思自动友链网
  • 淘宝客怎么建设自己网站wordpress links插件
  • 深圳设计网站公司网站芜湖网站建设工作室
  • 礼品类网站建设策划方案郑州手机网站制作
  • 江桥做网站wordpress代码高亮插件
  • 合肥网站制作哪家好建设网站培训班
  • 优化站诊断山东大型网站建设
  • 网页设计与制作个人网站网络开发工程师
  • 沈阳网站关键词优化哪家好外贸营销网站制作公司
  • 连云港做网站的临沂网站建设有哪些
  • 做毕设的网站万wordpress图片怎么居中
  • 首页网站模板网站外链分析怎么做
  • so域名的网站有哪些结合公众号小店做网站
  • 阜宁专业做网站做信息网站能挣钱吗
  • wordpress 怎么手动更新宝安网站 建设seo信科
  • 腾讯的网站建设用了多少钱找人合伙做网站平台