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

题库网站建设的绩效指标网站后台怎么做飘窗

题库网站建设的绩效指标,网站后台怎么做飘窗,最+的wordpress书,租用服务器这个题比较经典,可以用多个算法来求解,分别给出各个算法的求解方法,主要是分为第一部分的多源BFS求每个位置的距离和第二部分求(0,0)到(n-1,n-1)的最短路径(可以用多种方法求) 目录 多源BFS求最短路径枚举安全系数判断…

这个题比较经典,可以用多个算法来求解,分别给出各个算法的求解方法,主要是分为第一部分的多源BFS求每个位置的距离和第二部分求(0,0)到(n-1,n-1)的最短路径(可以用多种方法求)

目录

  • 多源BFS
  • 求最短路径
    • 枚举安全系数判断是否可行
      • 枚举安全系数
      • 路径是否存在

多源BFS

首先是要求得每个点距离最近的小偷所在位置的距离长度:
暴力枚举每个小偷所在位置,更新所有点到该小偷位置的距离,数据量为400,假设每个位置都有小偷,小偷数量达到400*400,再加上枚举每个位置,最后的复杂度为O(400 * 400 * 400 * 400),即O(n^4)会超时;
多源BFS求距离:多源BFS

// 以所有小偷为起点进行多源 bfsmemset(dis, -1, sizeof(dis));for (int i = 0; i < n; i++) for (int j = 0; j < m; j++) if (grid[i][j] == 1) {q.push(pii(i, j));dis[i][j] = 0;}while (!q.empty()) {pii p = q.front(); q.pop();int i = p.first, j = p.second;for (int k = 0; k < 4; k++) {int ii = i + dir[k][0], jj = j + dir[k][1];if (ii < 0 || jj < 0 || ii >= n || jj >= m || dis[ii][jj] >= 0) continue;q.push(pii(ii, jj));dis[ii][jj] = dis[i][j] + 1;}}

求最短路径

枚举安全系数判断是否可行

枚举答案看是否存在满足答案的路径。
这个思路采用逆向思维方式,不是枚举最短路径判断安全系数,而是枚举安全系数判断对应的最短路径是否存在,也是分为两部分,一部分是如何枚举安全系数,另一部分是如何判断只经过安全系数为lim并且连通起点到终点的路径是否存在。
枚举路径中安全系数(经过的格子的最小值)可以是哪些,相当于枚举只经过安全系数为lim的路径,路径中经过的格子安全系数全都大于等于lim,能否从起点到达终点;然后让这个lim尽可能地大。

枚举安全系数

  1. 可以直接从最大的开始枚举,找到一个符合条件的就可以结束了,O(n)
//直接从大到小枚举for(int i=min(dis[0][0],dis[n-1][m-1]);i>=0;i--){if(check(i)) return i;}
  1. 二分枚举, O(logn) 【最小值最大或者是最大值最小问题】
//二分int l=0,r=min(dis[0][0],dis[n-1][m-1]);while(l<r){int mid=(l+r+1)>>1;if(check(mid)) l=mid;else r=mid-1;}

路径是否存在

判断路径上的安全系数为lim,也就是之前求出来的所有节点的值大于等于lim的连接起点到终点的路径是否存在,有多种方法,bfs,dfs,并查集,只要判断起点和终点连通就行。

  1. BFS
    bfs检查时间,每个位置处遍历一次,复杂度为O(n^2)
    //通过一次bfs,检查能否只经过安全系数大于等于lim的格子,从左上角走到右下角bool check(int lim){q.push({0,0});memset(visited, 0, sizeof(visited));visited[0][0]=true;while(!q.empty()){pii p = q.front(); q.pop();int i = p.first, j = p.second;for (int k = 0; k < 4; k++) {int ii = i + dir[k][0], jj = j + dir[k][1];if (ii < 0 || jj < 0 || ii >= n || jj >= m || dis[ii][jj]<lim ||visited[ii][jj]) continue;q.push(pii(ii, jj));visited[ii][jj]=true;}}return visited[n-1][n-1];}
  1. DFS
    深搜不行,因为涉及到回溯,导致每个节点可能访问多次,导致深搜的时间复杂度无法控制在O(n^2)内,会超时。

  2. 并查集判断(0,0)和(n-1,n-1)是否连通

   int find(int x){if(p[x]==x) return x;return p[x]=find(p[x]);}//并差集判断bool check(int lim){//初始化并查集每个元素是自己,将二维的数组拉成一维的int x=0;for(int i=0;i<n;i++){for(int j=0;j<m;j++){p[x]=x;x++; }}//将每个节点与周围节点合并for(int i=0;i<n;i++){for(int j=0;j<m;j++){if(dis[i][j]<lim) continue;int a=find(i*n+j);for (int k = 0; k < 4; k++) {int ii = i + dir[k][0], jj = j + dir[k][1];if (ii < 0 || jj < 0 || ii >= n || jj >= m || dis[ii][jj]<lim ) continue;int b =find(ii*n+jj);if(a!=b)  p[b]=a;  //合并}}}return find(0)==find(n*n-1) ;}
http://www.yayakq.cn/news/160202/

相关文章:

  • 山东网站空间营销培训总结
  • 投放广告的网站笔记 发布 wordpress
  • 有什么网站可以做问卷调查上海模板建站多少钱
  • 高端大气的网站首页p2p网站建设教程
  • 余姚网站建设设计威联通怎么建设网站
  • 品牌网站和优化网站大连建筑工程网
  • 阜阳讯拓网站建设公司北京中企动力科技股份有限公司
  • 在线音乐网站开发网站多次提交
  • 网站建设收费流程手机网站如何做外链
  • 西安企业网站建设多少钱南昌网站建设价位
  • 深圳网站制作 优选灵点网络网页制作平台有哪些
  • 珠海网站推广大型门户网站建设哪专业
  • 海鲜网站开发目的在于网络营销渠道的组成要素包括
  • 如何做网站的的关键词惠州网站开发
  • 浙江中企建设集团有限公司网站外贸网站建设石家庄
  • 长沙php的网站建设公司二手车网站的建设
  • 全网黄页网站wordpress数据库名称
  • 北京企业网站建设价格网络推广有效果吗
  • 阿凡达网站建设网云南网站建设快速排名
  • 上海龙华医院的网站建设建设公益网站多少钱
  • 网站改版 seo手机微信小程序怎么制作
  • 微网站制作工具有哪些北辰集团网站建设
  • 网站改版怎么做301电子商务网站建设实训步骤
  • 网站app公众号先做哪个比较好最新的国外新闻10条
  • 如何判断网站开发语言沉浸式展厅搭建商
  • 2003网站建设安全电子商务网站设计
  • 自己做的小说网站要交税吗用vultr做网站
  • 网站建设缺陷设计网页步骤
  • 国开网站怎么做网站设计深圳要联系方式吗?
  • 网站建设分金手指排名十七页面设计专业