图论|207. 课程表 210. 课程表 II

207. 课程表

你这个学期必须选修 numCourses 门课程,记为 0 到 numCourses - 1 。
在选修某些课程之前需要一些先修课程。 先修课程按数组 prerequisites 给出,其中 prerequisites[i] = [ai, bi] ,表示如果要学习课程 ai 则 必须 先学习课程 bi 。
例如,先修课程对 [0, 1] 表示:想要学习课程 0 ,你需要先完成课程 1 。
请你判断是否可能完成所有课程的学习?如果可以,返回 true ;否则,返回 false。
示例 1:
输入:numCourses = 2, prerequisites = [[1,0]]
输出:true
解释:总共有 2 门课程。学习课程 1 之前,你需要完成课程 0 。这是可能的。
示例 2:
输入:numCourses = 2, prerequisites = [[1,0],[0,1]]
输出:false
解释:总共有 2 门课程。学习课程 1 之前,你需要先完成​课程 0 ;并且学习课程 0 之前,你还应先完成课程 1 。这是不可能的。
题目链接:207. 课程表
使用拓扑排序的解法

class Solution {//拓扑排序解法 将有向无环图转换成线性序列public boolean canFinish(int numCourses, int[][] prerequisites) {//准备工作//1.节点的入度(每次只能选入度为0的课)//2.依赖这门课的后续课(选当前课哪些节点的入度会被影响)’//如何判断选择完所有的课//BFS结束时,所有节点入度为0 或者 记录入列的节点个数等于门数则可以上完所有课程//入度数组 int[] inDegree=new int[numCourses];Arrays.fill(inDegree, 0);Map<Integer, List<Integer>> adjacencyList = new HashMap<>(); // 邻接表  // 初始化入度数组和邻接表  for (int[] prerequisite : prerequisites) {  inDegree[prerequisite[0]]++; // 计算课程的入度  if (adjacencyList.containsKey(prerequisite[1])) {  // 如果课程已经在邻接表中,添加依赖它的后续课程  adjacencyList.get(prerequisite[1]).add(prerequisite[0]);  } else {  // 如果课程不在邻接表中,新建一个列表存储后续课程  List<Integer> list = new ArrayList<>();  list.add(prerequisite[0]);  adjacencyList.put(prerequisite[1], list);  }  }  Queue<Integer> queue=new LinkedList<>();  ;//度为0则入列for(int i=0;i<inDegree.length;i++){if(inDegree[i]==0){queue.offer(i);}}int count=0;while (!queue.isEmpty()) {  int currentCourse = queue.poll(); // 出列一个课程  count++; // 已选课程数加1  if (adjacencyList.containsKey(currentCourse)) {  // 获取当前课程的所有后续课程  for (int nextCourse : adjacencyList.get(currentCourse)) {  inDegree[nextCourse]--; // 后续课程的入度减1  if (inDegree[nextCourse] == 0) {  // 如果入度减为0,加入队列  queue.offer(nextCourse);  }  }  }  }  return count == numCourses;}
}

多了一个路径的记录

class Solution {public int[] findOrder(int numCourses, int[][] prerequisites) {int[] reslut=new int[numCourses];ArrayList<Integer> tmpresult=new ArrayList<Integer>();//存储课程的入度,即指向该节点的节点Queue<Integer> queue=new LinkedList<>();int[] inDegree=new int[numCourses];Arrays.fill(inDegree, 0);//存储课程的后续节点(HashMap<Integer,List<Integer>>)HashMap<Integer,List<Integer>> map=new HashMap<>();for(int[] prerequisite : prerequisites){inDegree[prerequisite[0]]++;if(!map.containsKey(prerequisite[1])){List<Integer> list=new ArrayList<>();list.add(prerequisite[0]);map.put(prerequisite[1],list);}else{map.get(prerequisite[1]).add(prerequisite[0]);}}//找到入度为0的节点为先选课程for(int i=0;i<inDegree.length;i++){if(inDegree[i]==0){queue.offer(i);}}System.out.println(queue.size());if(queue.size()==0){return new int[0];}while(!queue.isEmpty()){Integer node=queue.poll();tmpresult.add(node);if (map.containsKey(node)) {List<Integer> tmpmap=map.get(node);for(int i=0;i<tmpmap.size();i++){inDegree[tmpmap.get(i)]--;if(inDegree[tmpmap.get(i)]==0){queue.offer(tmpmap.get(i));}}}}if(tmpresult.size()!=numCourses){//new int[0]是空的数组return new int[0];}else{for (int i = 0; i < tmpresult.size(); i++) {reslut[i] = tmpresult.get(i);}return reslut;}}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/708191.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Spark Bloom Filter Join

1 综述 1.1 目的 Bloom Filter Join&#xff0c;或者说Row-level Runtime Filtering&#xff08;还额外有一条Semi-Join分支&#xff09;&#xff0c;是Spark 3.3对运行时过滤的一个最新补充   之前运行时过滤主要有两个&#xff1a;动态分区裁剪DPP&#xff08;开源实现&am…

MongoDB聚合运算符:$concat

文章目录 语法举例 $concat聚合运算符返回多个字符串连接后的结果。 语法 { $concat: [ <expression1>, <expression2>, ... ] }<expression>可以是任何可以解析为字符串的表达式。如果表达式解析为null或引用的字段不存在&#xff0c;则返回null。 举例 …

迭代器模式:分离遍历逻辑与数据结构,实现统一访问接口与灵活扩展

文章目录 一、引言二、应用场景与技术背景三、模式定义与实现四、优缺点分析总结&#xff1a; 一、引言 ​ 迭代器模式&#xff08;Iterator Pattern&#xff09;是一种行为型设计模式&#xff0c;它提供了一种方法顺序访问聚合对象的元素&#xff0c;而又不暴露其底层表示。迭…

DFS中的连通性和搜索顺序

宽搜一般要手写一个队列&#xff0c;深搜一般是用系统栈来实现的。 DFS之连通性模型 1112. 迷宫 - AcWing题库 import java.util.*;public class Main{static int N 110, ha, la, hb, lb, n;static char[][] g new char[N][N];static boolean[][] st new boolean[N][N];st…

顶顶通呼叫中心中间件-使用http接口方式把在通话的机器人话术手动转给人工坐席分机操作步骤(mod_cti基于FreeSWITCH)

顶顶通呼叫中心中间件-机器人话术中手动转接到人工坐席分机上讲解(mod_cti基于FreeSWITCH) 需要了解呼叫中心中间件可以点此链接添加联系方式顶顶通小孙 一、操作步骤 1、自动外呼进入机器人话术 这里就不详细说了&#xff0c;可以去参考我的这一篇文章自动外呼进入机器人 …

nginx 日志,压缩,https功能介绍

一&#xff0c; 自定义访问日志 &#xff08;一&#xff09;日志位置存放 1&#xff0c;格式 2&#xff0c; 级别 level: debug, info, notice, warn, error, crit, alert, emerg 3&#xff0c;示例 服务机定义 错误日志存放位置 客户机错误访问 查看错误日志 4&#xff…

DAY9-防病毒AV概述

DNS过滤 URL过滤和DNS过滤对比

C#面:ref 和 out 的区别

ref 关键字&#xff1a; 在使用 ref 关键字时&#xff0c;传递的参数必须在方法调用之前进行初始化。在方法内部&#xff0c;对 ref 参数的任何修改都会影响到原始变量。ref 参数在方法内部和外部都必须具有相同的类型。 out 关键字 out 参数在方法内部必须被赋值。在使用 ou…

广和通5G智能模组SC171支持Android、Linux和Windows系统,拓宽智能物联网应用

世界移动通信大会2024期间&#xff0c;广和通宣布&#xff1a;5G智能模组SC171除支持Android操作系统外&#xff0c;还兼容Linux和Windows系统&#xff0c;帮助更多智能终端客户快速迭代产品&#xff0c;拓宽智能化应用覆盖范围。 广和通SC171系列基于高通QCM6490物联网解决方案…

oracle with check option 学习

with check option保证了通过视图进行的修改&#xff0c;必须也能通过该视图看到修改后的结果&#xff1b; 你插入&#xff0c;那么插入这条记录在刷新视图后必须可以看到&#xff1b; 如果修改&#xff0c;修改完的结果也必须能通过该视图看到&#xff1b; scott登录了以后创…

【Java程序设计】【C00320】基于Springboot的招生宣传管理系统(有论文)

基于Springboot的招生宣传管理系统&#xff08;有论文&#xff09; 项目简介项目获取开发环境项目技术运行截图 项目简介 这是一个基于Springboot的招生宣传管理系统&#xff0c;本系统有管理员以及招生人员二种角色&#xff1b; 前台&#xff1a;首页、专业介绍、师资力量、联…

Vue3.0+TS管理系统基础使用之变量声明、计算属性、监听属性

将近一年没写过管理系统了&#xff0c;上一次用的还是vue2js&#xff0c;这次接手的项目是Vue3ts&#xff0c;一眼看过去好熟悉的style&#xff0c;第二眼开始蒙&#xff0c;数据写哪&#xff1f;计算属性咋写啊&#xff1f; 这里用到了一个第三方库vue-property-decorator。 …

Spring Boot项目中如何上传头像?

在我们常见的各大App中&#xff0c;或多或少我们都见过上传头像的功能吧&#xff1f;&#xff1f; 但是在Spring Boot项目中如何上传头像呢&#xff1f; 上传头像主要用到RequestPart注解 来看一下小编的代码吧&#xff01; RestController RequestMapping("/param"…

cartographer ceres后端优化

这里引用一篇文章 https://zhuanlan.zhihu.com/p/567635409 因为cartographer中的代码有的地方添加了AddParameterBlock,有的地方没有添加,会引起歧义,原来AddParameterBlock可以隐式添加优化变量,这篇文章介绍了具体原因,核心内容如下: AddParameterBlock的作用作用一:…

服务器机房安全守护:五大物理安全实践

服务器机房是数字企业的心脏。无论是企业家还是经验丰富的IT专业人员&#xff0c;都知道服务器机房的安全性至关重要。如果没有采用适当的物理安全措施&#xff0c;其服务器很容易受到盗窃、人为破坏和自然灾害的破坏。 在保护服务器机房的领域内&#xff0c;需要采用多方面的…

鸿蒙应用程序包安装和卸载流程

开发者 开发者可以通过调试命令进行应用的安装和卸载&#xff0c;可参考多HAP的调试流程。 图1 应用程序包安装和卸载流程&#xff08;开发者&#xff09; 多HAP的开发调试与发布部署流程 多HAP的开发调试与发布部署流程如下图所示。 图1 多HAP的开发调试与发布部署流程 …

16. QML中的一些粒子特效

1.说明 在使用unity开发游戏时&#xff0c;都会涉及到一些特效的开发。实际上在QML中也提供了一些可以做特效的控件&#xff0c;称之为粒子系统。本篇博客主要记录一些使用粒子做特效的方式。 特效–火焰效果&#xff1a; 2. 案例汇总 2.1 案例1 效果展示&#xff1a; 粒子…

TypeScript 类型断言 关于 “ as “ 语法的各种用法

在 TypeScript 中&#xff0c;as 关键字用于类型断言&#xff0c;允许你将某个值强制转换为你期望的类型。下面是一些使用as关键字将值断言为不同类型的例子&#xff1a; 断言为 Object let someValue: any { ... }; let obj someValue as Object;断言为 string let someV…

标准库`random`函数大全:探索Python中的随机数生成【第107篇—`random`函数大全】

标准库random函数大全&#xff1a;探索Python中的随机数生成 随机数在计算机科学和数据科学领域中扮演着重要角色&#xff0c;Python的标准库中提供了random模块&#xff0c;用于生成各种随机数。本篇博客将深入探讨random模块的各种函数&#xff0c;以及它们的应用场景和代码…

MATLAB中的makeweight函数

W makeweight(dcgain,[freq,mag],hfgain) W makeweight(dcgain,[freq,mag],hfgain,Ts) W makeweight(dcgain,[freq,mag],hfgain,Ts,N) W makeweight(dcgain,wc,hfgain,___) W makeweight(dcgain,wc,hfgain&#xff0c;___)表示增益交叉频率wc。该语法相当于将…