Loading [MathJax]/jax/input/TeX/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >拓扑排序Golang实现

拓扑排序Golang实现

原创
作者头像
dddyge
发布于 2022-10-19 15:09:54
发布于 2022-10-19 15:09:54
80800
代码可运行
举报
文章被收录于专栏:思考与总结思考与总结
运行总次数:0
代码可运行

以前一直不太懂拓扑排序的实现,今天在知乎上面看到一篇文章讲拓扑排序,讲的特别清楚,一下子明朗了。链接如下:https://zhuanlan.zhihu.com/p/135094687。

其实就是有向无环图的广度优先搜索,寻找一条可行的道路,且每个节点的先决条件有特定的几个。这样去理解拓扑排序就很好理解了。基于拓扑排序的题目有最典型的207题:课程表1, 210题:课程表2。这两道题都是很典型的使用广度优先搜索来实现拓扑排序。思路是:通过将先决条件作为入度数组,以及记录自身为另外节点的先决条件的数组(也就是出度数组),将入度为0的元素加入到队列,然后遍历出度数组,将子元素的入度-1,再将入度为0的元素加入到队列中去。1136题并行课程也是一道拓扑排序的题目:思路是一个学期只能学习一轮,这个题目单独拿出来讲是因为我觉得这道题类似二叉树的层次遍历,每次出队的时候跟课程表系列的题目不同,只需要将一轮队列中的元素个数遍历完才能增加一次计数,然后才能进行下一轮遍历队列。这样通过判断几轮进行下来的课程数是否是题目要求的数量进行对比即可知道是否有可行的拓扑排序。以下是该题目的解,在此记录一下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
func minimumSemesters(n int, relations [][]int) int {
    inEdge, outEdge := make([]int, n + 1), make([][]int, n + 1)
    term := 0
    queue := make([]int, 0)
    cntCourse := 0
    for _, relation := range relations {
        outEdge[relation[0]] = append(outEdge[relation[0]], relation[1])
        inEdge[relation[1]]++
    }
    for i := 1; i < n + 1; i++ {
        if inEdge[i] == 0 {
           queue = append(queue, i) 
        }
    }

    for len(queue) != 0 {
        term++
        n := len(queue)
        for i := 0; i < n; i++ {
            poll := queue[0]
            queue = queue[1:]
            cntCourse++
            for _, next := range outEdge[poll] {
                inEdge[next]--
                if inEdge[next] == 0 {
                    queue = append(queue, next)
                }
            }
        }
    }
    if cntCourse != n {
        return -1
    }
    return term
}

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
golang刷leetcode 经典(2)拓扑排序
「选课问题」本质上是一个top排序问题,top排序问题其实是有向图的遍历问题,因此可以dfs和bfs进行解。
golangLeetcode
2022/08/02
3220
拓扑排序原理与解题套路
其实最开始学习算法,听到拓扑排序这几个字我也是懵逼的,后来学着学着才慢慢知道是怎么一回事。关于 拓扑 这个词,在网上找到这么一段解释:
五分钟学算法
2019/09/03
5100
图算法-LeetCode 210、332(拓扑排序,深度搜索,BFS,DFS)
现在你总共有 n 门课需要选,记为 0 到 n-1。 在选修某些课程之前需要一些先修课程。例如,想要学习课程 0 ,你需要先完成课程 1 ,我们用一个匹配来表示他们: [0,1] 给定课程总量以及它们的先决条件,返回你为了学完所有课程所安排的学习顺序。 可能会有多个正确的顺序,你只要返回一种就可以了。如果不可能完成所有课程,返回一个空数组。
算法工程师之路
2019/10/23
6300
golang刷leetcode 技巧(10) 课程表(II)
在选修某些课程之前需要一些先修课程。例如,想要学习课程 0 ,你需要先完成课程 1 ,我们用一个匹配来表示他们: [0,1]
golangLeetcode
2022/08/02
1860
八十六、从拓扑排序探究有向图
关于排序,其实还有很多,比如常见的希尔排序,桶排序,计数排序和基数排序,由于要过渡到数据结构有向图,因此需要了解拓扑排序和邻接矩阵概念。
润森
2022/08/17
4890
八十六、从拓扑排序探究有向图
DFS,BFS(拓扑排序)的简单应用,
1:用来确定在互联网中从一个结点到另一个结点(一个网络到其他网络的网关)的最佳路径。一种建模方法是采用无向图,其中顶点表示网络结点,边代表结点之间的联接。使用这种模型,可以采用广度优先搜索来帮助确定结点间的最小跳数。
zhangjiqun
2024/12/16
790
DFS,BFS(拓扑排序)的简单应用,
Leetcode | 第7节:DFS,BFS
这一节我们介绍一下DFS和BFS,也就是深度优先搜索和广度优先搜索。搜索算法也是很多题目我们所会考虑的第一个算法,因为想法直接而易想。本来是要介绍树有关的内容的,但是研究了一下材料发现,其实树相关的题目还是挺多需要用到我们这一节说到的搜索算法的,所以我们就临时换了一下介绍顺序。
学弱猹
2021/08/10
6620
Leetcode | 第7节:DFS,BFS
【拓扑排序】课程表 && 课程表Ⅱ
你这个学期必须选修 numCourses 门课程,记为 0 到 numCourses - 1 。
利刃大大
2025/03/13
1670
课程表
你这个学期必须选修 numCourse 门课程,记为 0 到 numCourse - 1 。在选修某些课程之前需要一些先修课程。 例如,想要学习课程 0 ,你需要先完成课程 1 ,我们用一个匹配来表示他们:[0, 1]。给定课程总量以及它们的先决条件,请你判断是否可能完成所有课程的学习?
零式的天空
2022/03/28
8590
leetcode 207. 课程表---拓扑排序篇一
本题涉及到了拓扑排序相关的概念,如果对拓扑排序不了解的,建议看这篇文章AOV网与拓扑排序
大忽悠爱学习
2021/11/15
6710
LeetCode 1136. 平行课程(拓扑排序)
给你一份课程关系表 relations[i] = [X, Y],用以表示课程 X 和课程 Y 之间的先修关系:课程 X 必须在课程 Y 之前修完。
Michael阿明
2021/02/19
7610
BFS:解决拓扑排序问题
要知道什么拓扑排序我们首先要知道什么是有向无环图,有向无环图我们看名字其实就很容易理解,有向就是有方向,无环就是没有环形结构,这里我们展示一下有向无环图和有向有环图:
用户11305458
2024/10/09
1990
BFS:解决拓扑排序问题
初识广度优先搜索与解题套路
先来看看其中比较简单的数据结构 - 链表,它和数组类似,也是一个线性的结构,简单来说就是一条路径,你从头开始遍历,最终会将链表上面的节点都访问到,到达终点。
五分钟学算法
2019/10/09
6190
【C++】拓扑排序(BFS)
通过入度和出入我们可以判断活动的进行顺序,活动度数为0的活动先进行没进行完后,将该活动的出度清空,下一个入度为0的节点就是该节点之后要进行的活动,以此类推,直到最后没有活动节点,如果只存在有一个入度的节点(成环)。
啊QQQQQ
2024/11/19
1660
【C++】拓扑排序(BFS)
golang刷leetcode图(2)课程表排序
在选修某些课程之前需要一些先修课程。例如,想要学习课程 0 ,你需要先完成课程 1 ,我们用一个匹配来表示他们: [0,1]
golangLeetcode
2022/08/02
2400
【python-leetcode210-拓扑排序】课程表Ⅱ
在选修某些课程之前需要一些先修课程。 例如,想要学习课程 0 ,你需要先完成课程 1 ,我们用一个匹配来表示他们: [0,1]
西西嘛呦
2020/08/26
5720
【python-leetcode210-拓扑排序】课程表Ⅱ
拓扑排序 bfs与dfs实现
拓扑排序:对一个有向图的顶点进行"排序"。着重点在于图中各个顶点的连接关系,这种连接关系也叫拓扑关系。
公众号guangcity
2022/01/18
1.2K0
拓扑排序-HDU2647 Reward
什么是拓扑排序? 简单来说,在做一件事之前必须先做另一(几)件事都可抽象为图论中的拓扑排序,比如课程学习的先后,安排客人座位等。 一个图能拓扑排序的充要条件是它是有向无环图。将问题转为图,比如A指向B代表完成B前要先完成A,那么用数组记录入度,从入度为0的开始搜索(bfs/dfs)和维护数组,即可得到拓扑排序。
唔仄lo咚锵
2020/09/15
4010
LeetCode 210. 课程表 II(拓扑排序)
在选修某些课程之前需要一些先修课程。 例如,想要学习课程 0 ,你需要先完成课程 1 ,我们用一个匹配来表示他们: [0,1]
Michael阿明
2020/07/13
4480
图算法-LeetCode 133、207(拓扑排序,邻接表建立)
给定无向连通图中一个节点的引用,返回该图的深拷贝(克隆)。图中的每个节点都包含它的值 val(Int) 和其邻居的列表(list[Node])。
算法工程师之路
2019/09/30
1.3K0
图算法-LeetCode 133、207(拓扑排序,邻接表建立)
相关推荐
golang刷leetcode 经典(2)拓扑排序
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验