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

做网批有专门的网站吗wordpress和t

做网批有专门的网站吗,wordpress和t,还有网站吗,做亚马逊需要的图片外链网站Problem: 210. 课程表 II 文章目录 思路解题方法Code 思路 本题是经典拓扑排序模板,通过DFS和BFS两种方式进行实现。 解题方法 DFS DFS方法的重点在于如何标记节点状态,初做题者如果只用未访问和已访问两种状态很容易陷入死结。正确的做法是使用三种状…

Problem: 210. 课程表 II

文章目录

  • 思路
  • 解题方法
  • Code

思路

本题是经典拓扑排序模板,通过DFSBFS两种方式进行实现。

解题方法

  1. DFS

    1. DFS方法的重点在于如何标记节点状态,初做题者如果只用未访问和已访问两种状态很容易陷入死结。
    2. 正确的做法是使用三种状态未访问,正在访问和已访问,原因是原因是如果想遇到环一定是遇到了本次DFS路径上的节点,他们属于特殊状态需要标记出。而遇到尚未访问的和别的路径访问过的节点都是没有问题的。
  2. BFS

    1. BFS方法的重点在于多源,这也是BFS本身的一个特性,可以在图的多点同时进行BFS,参考题目994. 腐烂的橘子就很好地利用了这一特点。所以需要同时在图的多个地方进行操作时可以考虑多源BFS
    2. 首先将节点入度统计出来,初始化时加入入度为0的节点,之后每次出队节点就把节点指向的节点的入度减少,再入队新产生的入度为0的节点,如此重复。
    3. 这一做法和手写拓扑排序十分类似。结果中如果没有包含所有节点即说明图中有环,无法拓扑排序。

Code

代码中同时有DFSBFS两种实现

class Solution {
public:vector<int> findOrder(int numCourses, vector<vector<int>>& prerequisites) {vector<vector<int>> e(numCourses);vector<int> degree(numCourses);for(auto& prerequisity : prerequisites) {e[prerequisity[1]].push_back(prerequisity[0]);degree[prerequisity[0]]++;}auto res = dfs(numCourses, e);// auto res = bfs(numCourses, e, degree);return res;}/* DFS */vector<int> dfs(int n, vector<vector<int>>& e) {vector<int> vis(n, 0);  // 0未访问, 1正在访问, 2已被收录stack<int> s;bool valid = true;for(int i = 0; i < n; i++) {if(vis[i] == 0) dfs_rec(n, e, vis, s, valid, i);}if(valid == false) return {};vector<int> res;while(!s.empty()) {res.push_back(s.top());s.pop();}return res;}void dfs_rec(int n, vector<vector<int>>& e, vector<int>& vis, stack<int>& s, bool& valid, int cur) {if(vis[cur] == 1) {valid = false;return;}if(vis[cur] == 2) {return;}vis[cur] = 1;for(auto eg : e[cur]) {dfs_rec(n, e, vis, s, valid, eg);}s.push(cur);vis[cur] = 2;return;}/* BFS */vector<int> bfs(int n, vector<vector<int>>& e, vector<int>& degree) {queue<int> q;for(int i = 0; i < n; i++) {if(degree[i] == 0) q.push(i);}vector<int> res;while(!q.empty()) {auto cur = q.front();q.pop();res.push_back(cur);for(auto& eg : e[cur]) {degree[eg]--;if(degree[eg] == 0) q.push(eg);}}if(res.size() < n) return {};return res;}
};
http://www.yayakq.cn/news/656245/

相关文章:

  • 网站备案怎么转入网站建设合同 包括什么
  • 建视频网站系统青岛东八区创意做网站
  • 怎么做直播室的网站淮安企业网站制作
  • dede后台网站地图怎么做wordpress支付宝红包
  • 网站主题 模板开源短视频sdk推荐
  • 福州作公司网站的公司南京定制网站
  • 济南网站制作0531soso十个程序员必备的网站
  • 工商局网站怎么做身份确认东莞合网站建设
  • 用什么软件做网站hao网站被降权会发生什么影响吗
  • 招远做网站公司电商网站网址
  • 长沙教育建设信息网站织梦制作手机网站模板
  • 河北建设机械协会网站智慧社区背景图
  • 网站建设电商怎么做自己的店铺网站
  • 南京制作网站公司网站娄底做网站的公司
  • 俄语网站制作字体设计软件 免费
  • 外贸网站建设哪里好WordPress企业 破解主题
  • 婚介网站建设南城区网站仿做
  • 网站建设 苏州wordpress织梦
  • 南京制作网站培训学校合肥专业做网站公司有哪些
  • 企业免费网站设计公司异度空间图书馆主题 wordpress
  • 网站建设方式小程序二维码怎么获取
  • 公司网站建设有哪些山东网站建设比较好
  • 网站建设上的新闻医疗网站设计
  • 手机网站一般做多大尺寸做一个网站做少钱
  • 网站备案查询可以怎么找回密码
  • 昆明制作网站费用简洁网站布局
  • 网站建设不赚钱谷歌排名优化
  • 招投标网站开发费用wordpress安装 503
  • 中国做网站最大的公司吴江设计网站公司
  • 广西建设监理协会网站安丘市建设局网站