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

阿里巴巴网站的pc端和手机端怎么做的西安seo黑

阿里巴巴网站的pc端和手机端怎么做的,西安seo黑,唐山网站建设汉狮怎么样,中企动力科技股份有限公司电话题面 给定一个有向图,每个点出度最大为一,现在问你图中最长的环的长度是多少,如果没有环输出 -1, 1 ≤ n ≤ 1 0 5 1 \le n \le 10^5 1≤n≤105。 题面 解题思路 我们直接说结论,我们从任意一个点出发,用…

题面

给定一个有向图,每个点出度最大为一,现在问你图中最长的环的长度是多少,如果没有环输出 -1, 1 ≤ n ≤ 1 0 5 1 \le n \le 10^5 1n105
题面

解题思路

我们直接说结论,我们从任意一个点出发,用一个数组存下来到达每一个点的最短步数,如果发现一个点之前已经被遍历过了,那么这个点一定是一个环的起点和终点,环的长度是当前的步数减去这个点的最短步数。

下面稍微证明一下,我们来看题目中给出的条件,每一个点最多只有一条出边,那么这个条件告诉了我们两件事情:

  1. 边数比较小;
  2. 图中不存在以下情况:
    在这里插入图片描述

所以当我们遍历的时候,所有经过的点和边形成的一定是一个链型的结构。当发现有一个点重复遍历的时候,一定是返回到了链上前面的某一个点,形成了一个环,我们统计一下答案就好了。

除此之外我们要注意,题目没有保证任意两点之间可以互相到达,当我们遍历一次之后我们还要检查还有没有别的点我们没有遍历。

任意两次遍历是互不影响的,或者说一个环只可能出现在具体的一次遍历当中,所以当我们完成一次遍历的时候,直接把这次的点全部都删了就行,不然复杂度就上来了。

代码

class Solution {
public:int ans = -1; // 最终答案vector<int> dis; // 存最短步数void dfs(int x, int D, vector<int>& edges) // D 表示当前步数{if (dis[x] != 0) // 如果发现之前被遍历过了,说明可能存在环{if (dis[x] == -1) // -1 说明是之前的遍历,不用管return;ans = max(ans, D - dis[x]); // 否则就是存在环,记录答案return;}dis[x] = D; // 维护 disif (edges[x] != -1)dfs(edges[x], D + 1, edges); // 最多只有一个出度,就不用 for 循环了dis[x] = -1; // 遍历完成开始回溯了,直接把这个点删掉}int longestCycle(vector<int>& edges) {const int N = edges.size();dis.resize(100005, 0); for (int i = 0; i < N; i++) // 记得要遍历所有的点if (dis[i] == 0)dfs(i, 1, edges);return ans;}
};










本人能力有限,如有不当之处敬请指教!

http://www.dtcms.com/wzjs/76768.html

相关文章:

  • 做动画片的网站湖南关键词优化品牌价格
  • 网站建设哪家比较好个人网页制作完整教程
  • 建筑招聘求职网seo优化网页
  • 长春开发小程序开发青岛网络优化代理
  • 徐州做网站管理的公司今日郑州头条最新新闻
  • html框架北京首页关键词优化
  • 门户网站前期网络采集商家信息免费发布北京网站建设公司案例
  • 炫酷文字制作网站广州品牌seo推广
  • 网站正在建设中 色看颜色应该搜索哪些词汇
  • 网站建设junke100百度网盘官网下载
  • wordpress怎么限制建站数量seo研究所
  • 商贸公司营销网站建设百度推广开户代理
  • 北京企业网站建设价格竞价恶意点击犯法吗
  • 南昌做网站建设公司网络推广公司企业
  • 购物形式网站制作汕头seo优化公司
  • 手机免费网站空间外包网
  • 银川网站建设网络推广优化方案
  • 深圳网站公司注册今日特大新闻
  • 我的世界怎么自己做皮肤并上传网站百度的特点和优势
  • 如何做视频类网站建站abc官方网站
  • 版面设计图大全 模板重庆网站优化软件
  • 合肥网站建设设计seo排名优化首页
  • 电子商务网站建设合同书网站制作公司
  • 环保行业网站怎么做如何搭建网站平台
  • 实现web服务以发布公司网站好搜自然seo
  • 公司网站建设的好处电商网站设计论文
  • 免费ppt模板资源seo优化知识
  • 全运会为什么建设网站网店运营
  • 网站跳出率高怎么办百度小说风云榜总榜
  • 个人主页类网站开发背景网站制作的基本流程是什么