这篇文章主要介绍C语言如何实现拓扑排序,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
拓扑排序
以入度为0的做起点 vector<int> top_sort(){ priority_queue<int ,vector<int> ,greater<int > >Q; for(int i=1;i<=n;i++){ if(!indeg[i]){ Q.push(i); } } std::vector<int> TOP; while(!Q.empty()){ int T=Q.top(); Q.pop(); indeg[T]=-1; TOP.push_back(T); for(auto &e:graph[T]){ indeg[e]--; if(indeg[e]==0)Q.push(e); } }return TOP; } }
以上是“C语言如何实现拓扑排序”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。