Go语言圣经练习5.11

这篇博客介绍了如何在Go语言中实现拓扑排序,特别是在有向图中检测环的逻辑。作者参照C语言版本的思路,遵循最小改动原则,通过深度优先遍历来完成这一任务。文章详细阐述了实现过程,并提供了代码示例。
摘要由CSDN通过智能技术生成

前言

练习5.11: 现在线性代数的老师把微积分设为了前置课程。完善topSort,使其能检测有向图中的环。

没找到5.11的参考Go语言版,参考C语言版本的思路,结合原有的代码逻辑,在最小改动的原则上实现了Go语言版本的深度优先遍历拓扑排序环检测。
5.10、5.12 可参考 https://blog.csdn.net/taoshihan/article/details/101249100
参考的C语言版本 https://blog.csdn.net/qq_40507857/article/details/84305444

实现逻辑

用三种状态来标记访问的节点:未访问、正在访问、已访问;
初始情况,均为未访问;
未访问项访问时设置为正在访问,递归访问该项的前序课程,访问结束后设置为已访问;
若正在访问时遇到一个正在访问的课程,说明存在环,标记,退出。

代码

package main

import (
	"fmt"
	"sort"
)

func topoSort(m map[string][]string) map[int]string {
   
	var order = make(map[int]string)
 	index := 0
	seen := make(map[string]int) // 初始值默认为0, 与下面notvisit状态相对应
	const (
	    notvisit = <
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值