温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

C语言如何实现拓扑排序

发布时间:2022-01-15 14:14:09 来源:亿速云 阅读:126 作者:小新 栏目:编程语言

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

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI