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

wordpress 防sql注入上海高端seo公司

wordpress 防sql注入,上海高端seo公司,网上兼职网站怎么做的,新疆培训网站建设文章目录 判断图是否有环,是一个技术性的问题,当一个图规定了起点的时候,我们只需设置一个visited数组(初始值为False),当接下来访问到的结点i是visited[i]True的时候,我们就可以说存在一个环了…

文章目录

  • 判断图是否有环,是一个技术性的问题,当一个图规定了起点的时候,我们只需设置一个visited数组(初始值为False),当接下来访问到的结点i是visited[i]=True的时候,我们就可以说存在一个环了,这样的话,时间复杂度就是o(n)
  • 但是,如果图并有规定从哪一个顶点开始,那么我们应该如何判断这个图中是否存在环?由于没有规定是从哪一个点作为遍历的开始,所以要是采用上面的思路进行的话,就需要考虑从每一个点作为起点的情况,那么这样的话,时间复杂度就会来到o(n^2),那么应该怎么办?

下面介绍三色标记法,也就是将结点分为,未被访问、正在访问、已经访问过,这三种情况

三色标记法

  • 具体思路:
  • 对于每一个节点x,都定义三种颜色值(状态值):
  • 0,节点x尚未被访问到
  • 1,节点x正在访问中,dfs(x)尚未结束
  • 2,节点x已经完全访问完毕,dfs(x)已经返回

注意:只使用两种状态是不能处理是否存在环的

我们所说的,节点x正在访问中,是说我们正在递归处理节点x以及它的后续节点,dfs(x)尚未结束

  • 时间复杂度:每个节点只会被访问一次,每一条边也会被访问一次,所以时间复杂度是o(N+E)

在这里插入图片描述
在这里插入图片描述

  • 思路分析:直接套用三色标记法即可

Python思路

class Solution:def canFinish(self, numCourses: int, prerequisites: List[List[int]]) -> bool:g = [[] for _ in range(numCourses)]for a, b in prerequisites:g[b].append(a)colors = [0] * numCourses# 返回 True 表示找到了环def dfs(x: int) -> bool:colors[x] = 1  # x 正在访问中for y in g[x]:if colors[y] == 1 or colors[y] == 0 and dfs(y):return True  # 找到了环colors[x] = 2  # x 完全访问完毕return False  # 没有找到环for i, c in enumerate(colors):if c == 0 and dfs(i):return False  # 有环return True  # 没有环

C++思路

class Solution {
public:bool canFinish(int numCourses, vector<vector<int>>& prerequisites) {vector<vector<int>> g(numCourses);for (auto& p : prerequisites) {g[p[1]].push_back(p[0]);}vector<int> colors(numCourses);// 返回 true 表示找到了环auto dfs = [&](this auto&& dfs, int x) -> bool {colors[x] = 1; // x 正在访问中for (int y : g[x]) {if (colors[y] == 1 || colors[y] == 0 && dfs(y)) {return true; // 找到了环}}colors[x] = 2; // x 完全访问完毕return false; // 没有找到环};for (int i = 0; i < numCourses; i++) {if (colors[i] == 0 && dfs(i)) {return false; // 有环}}return true; // 没有环}
};

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

  • 思路分析:

python代码

class Solution {
public:bool canFinish(int numCourses, vector<vector<int>>& prerequisites) {vector<vector<int>> g(numCourses);for (auto p: prerequisites){g[p[1]].push_back(p[0]);}vector<int> colors(numCourses);auto dfs = [&](this auto && dfs,int x) -> bool{colors[x] = 1;for (int y : g[x]){if (colors[y] == 1 || colors[y] == 0 && dfs(y)){return true;}}colors[x] = 2;return false;};for (int i = 0; i < numCourses; i++){if (colors[i] == 0 && dfs(i)){return false;}}return true;}
};
http://www.dtcms.com/wzjs/36053.html

相关文章:

  • 长沙网站建设专家网络技术培训
  • 手机网站开发成本最新国际要闻
  • vue.js做静态网站陕西网站seo
  • 能用的手机网站微信广告平台推广
  • 做网站靠谱的公司网络营销的认知
  • 建站公司会有多大的坑百度指数是免费的吗
  • win8.1 做网站服务器如何结合搜索检索与seo推广
  • 江苏天德建设工程有限公司网站广东vs北京首钢
  • 上海网站建设学校seo优化或网站编辑
  • 如何建一个个人网站企业网站建设公司
  • 网站的总体风格包括东莞网络推广系统
  • 响应式网站建设服务商武汉百度推广多少钱
  • 网站页面模板 建设中上海网站seo公司
  • 怎么用链接提取视频保存百度seo快速排名
  • 整站优化哪家专业网站推广的渠道有
  • 做电信网站运营商站长网
  • 六安商城网站建设地址推广app赚钱的平台
  • 网站的域名是什么意思百度趋势搜索
  • 网站开发工程师 英文互联网营销外包公司
  • 企业微信下载官方网站百度免费下载
  • 深圳市坪山区住房和建设局网站中国seo排行榜
  • 如何买网站百度游戏客服在线咨询
  • 做正品的网站市场调研报告
  • 深圳开发网站建设买卖网交易平台
  • 网站开发者yotoonseo搜索引擎优化就业指导
  • 菏泽网站建设公司蓝希科技关键词分析工具有哪些
  • 做ppt比较好的网站网红推广团队去哪里找
  • 网站弹出代码阿里巴巴国际站
  • 搭建一个平台需要什么seo效果最好的是
  • sqlite 做网站广告推广免费