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

自己做视频网站流量钱pc网站优化排名

自己做视频网站流量钱,pc网站优化排名,wordpress虚拟主机vps,济南网站建设 选搜点oProblem: 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.yidumall.com/news/98284.html

相关文章:

  • 做服装有哪些好的网站公司网站建设哪个好
  • 网站模版安装教程哈尔滨网站建设
  • 大连网站开发培训价格百度风云榜排行榜
  • 做网站的素材哪里找的营销培训讲师
  • 研究生做网站开发免费建网站平台
  • 柳州网站开发武汉整站seo数据上云
  • 蛋糕电子商务网站建设方案简阳seo排名优化培训
  • 物流网站建设的小结一个产品营销策划方案
  • 网站换代理查图百度识图
  • 成都商城网站制作宁波网站制作设计
  • 微信第三方网站怎么做网络营销的策划方案
  • 天河网站建设服务贴吧aso优化贴吧
  • 进腾讯做游戏视频网站企业的互联网推广
  • 多语言外贸网站seo研究中心vip教程
  • 石家庄建设局网站最近发生的新闻大事
  • 网站报名照片怎么做营销软文300字
  • 响应式网站建设流程神童预言新冠2023结束
  • 合肥网站建设 乐云seob站推广网站mmm
  • 注册安全工程师报名条件和要求seo和sem是什么意思
  • 手机怎么安装网站程序北京网站托管
  • 南通网站制作专家厦门seo大佬
  • 北京外贸网站建设宁波seo自然优化技术
  • dede模板打网站显示栏logo搜狗关键词优化软件
  • 虚拟邮箱注册网站seo工具查询
  • 门户网站定制seo的最终是为了达到
  • 网站开发需求评估百度刷首页怎么刷
  • 娄星区建设局网站广州知名网络推广公司
  • 珠海十大网站建设公司武汉关键词排名推广
  • 网站留言板的作用sem代运营托管公司
  • 乐平网站国内b站不收费网站有哪些