C语言如何实现拓扑排序
更新:HHH   时间:2023-1-7


这篇文章主要介绍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语言如何实现拓扑排序”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注天达云行业资讯频道!

返回编程语言教程...