207. 课程表


思路

想象成有向图 一个结点代表一门课程

d表示所有课程的集合

dict1用来装有入度的结点以及对应的入度数(如:[0,1] 学了1才能学0:即1指向0,即只有0有入度 所以prerequisites每个值i的i[0]即为有入度的结点)

q表示当前层无入度的结点(入度为0)

nex:表示下一层无入度的结点

第一层:当前prerequisites无入度的结点

在遍历无入度结点时(代表选这门课程),因为有指向,所以 对应指向值的入度-1,当对应指向值入度为0时即作为下一层的无入度结点 循环遍历

遍历结束后,若dict1中有入度不为0的,说明这门课无法被选

python 复制代码
class Solution(object):
    def canFinish(self, numCourses, prerequisites):
        """
        :type numCourses: int
        :type prerequisites: List[List[int]]
        :rtype: bool
        """
        if len(prerequisites)==0 or len(prerequisites)==1:
            return True
        #课程集合
        d=set()
        #有入度的集合
        dict1={}
        for i in prerequisites:
            if i[0] in dict1:
                dict1[i[0]]+=1
            else:
                dict1[i[0]]=1
            d.add(i[0])
            d.add(i[1])
        
        q =[]
        #第一层要遍历的数(根结点),入度为0
        for i in d:
            if i not in dict1:
                q.append(i)
        #无入度为0的结点,成环 [[1,0],[0,1]]
        if q==[]:
            return False
        while q:
            nex=[]
            for i in q:
                for j in prerequisites:
                    if i==j[1]:
                        dict1[j[0]]-=1
                        if dict1[j[0]]==0:
                            nex.append(j[0])
            q=nex
        for i in dict1:
            if dict1[i]!=0:
                return False
        return True
相关推荐
Hgfdsaqwr3 小时前
Django全栈开发入门:构建一个博客系统
jvm·数据库·python
TracyCoder1233 小时前
LeetCode Hot100(15/100)——54. 螺旋矩阵
算法·leetcode·矩阵
开发者小天3 小时前
python中For Loop的用法
java·服务器·python
老百姓懂点AI4 小时前
[RAG实战] 向量数据库选型与优化:智能体来了(西南总部)AI agent指挥官的长短期记忆架构设计
python
喵手5 小时前
Python爬虫零基础入门【第九章:实战项目教学·第15节】搜索页采集:关键词队列 + 结果去重 + 反爬友好策略!
爬虫·python·爬虫实战·python爬虫工程化实战·零基础python爬虫教学·搜索页采集·关键词队列
Suchadar6 小时前
if判断语句——Python
开发语言·python
ʚB҉L҉A҉C҉K҉.҉基҉德҉^҉大6 小时前
自动化机器学习(AutoML)库TPOT使用指南
jvm·数据库·python
喵手6 小时前
Python爬虫零基础入门【第九章:实战项目教学·第14节】表格型页面采集:多列、多行、跨页(通用表格解析)!
爬虫·python·python爬虫实战·python爬虫工程化实战·python爬虫零基础入门·表格型页面采集·通用表格解析
weixin_445476687 小时前
leetCode每日一题——边反转的最小成本
算法·leetcode·职场和发展
0思必得07 小时前
[Web自动化] 爬虫之API请求
前端·爬虫·python·selenium·自动化