zoukankan      html  css  js  c++  java
  • acwing 848 有向图的拓扑序列

    地址 https://www.acwing.com/problem/content/description/850/

    题目描述
    给定一个n个点m条边的有向图,图中可能存在重边和自环。

    请输出任意一个该有向图的拓扑序列,如果拓扑序列不存在,则输出-1。

    若一个由图中所有点构成的序列A满足:对于图中的每条边(x, y),x在A中都出现在y之前,则称A是该图的一个拓扑序列。

    输入格式
    第一行包含两个整数n和m

    接下来m行,每行包含两个整数x和y,表示点x和点y之间存在一条有向边(x, y)。

    输出格式
    共一行,如果存在拓扑序列,则输出拓扑序列。

    否则输出-1。

    数据范围
    1≤n,m≤105

    样例

    输入样例:
    3 3
    1 2
    2 3
    1 3
    输出样例:
    1 2 3

    算法1
    拓扑排序流程为BFS 流程如下
    1 首先找到第一个入度为0 的点 放入待处理队列,记录答案拓扑数组中 拓扑的必要条件
    2 然后从该点连接的各个点 做以下操作:
    2.1 删除该边后,查看从该点连接的的点的入度
    2.2 如果入度为0 那么该点放入待处理队列,记录答案拓扑数组中, 再次进行BFS 直到待处理队列为空

    C++ 代码

    #include <iostream>
    
    #include <iostream>
    #include <vector>
    #include <queue>
    
    
    using namespace std;
    
    int n, m;
    vector<vector<int>> outvec(100010, vector<int>());      //入度记录
    vector<int> invec(100010, 0);;    //出度记录
    
    int main()
    {
        cin >> n >> m;
    
        for (int i = 0; i < m; i++) {
            int start; int end;
            cin >> start >> end;
            invec[end]++;
            outvec[start].push_back(end);
        }
        queue<int> q;
        for (int i = 1; i <= n; i++) {
            //找到第一个入度为0的点
            if (invec[i] == 0) {
                q.push(i);
                break;
            }
        }
    
        vector<int>  ret;
        while (!q.empty()) {
            int idx = q.front();
            q.pop();
    
            ret.push_back(idx);
    
            //抹掉这个点的所有出度边 与入度计数
            for (auto& e : outvec[idx]) {
                if (e != -1) {
                    invec[e]--; //该点入度减1
    
                    if (invec[e] == 0) {
                        q.push(e);
                    }
                    e = -1;  //抹掉该边
                }
            }
        }
    
        if(ret.size() == n)
            for (auto& e : ret) {
                cout << e << " ";
            }
        else
            cout << -1;
    
    
    
        return 0;
    }
    
    
    作者:defddr
    链接:https://www.acwing.com/solution/acwing/content/4196/
    来源:AcWing
    著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
    作 者: itdef
    欢迎转帖 请保持文本完整并注明出处
    技术博客 http://www.cnblogs.com/itdef/
    B站算法视频题解
    https://space.bilibili.com/18508846
    qq 151435887
    gitee https://gitee.com/def/
    欢迎c c++ 算法爱好者 windows驱动爱好者 服务器程序员沟通交流
    如果觉得不错,欢迎点赞,你的鼓励就是我的动力
    阿里打赏 微信打赏
  • 相关阅读:
    Python--day61--Django ORM单表操作之展示用户列表
    Python--day61 PyCharm连接MySQL工具的使用
    Python--day61--ORM介绍及Django使用ORM创建表
    Python--day49--ORM框架SQLAlchemy之relationship的使用(有时间要从新看,这里状态不好,没有仔细听)
    Python--day48--ORM框架SQLAlchemy之子查询
    Python--day48--ORM框架SQLAlchemy操作表
    Python--day48--ORM框架SQLAlchemy
    Python--day48--面向对象回顾
    web api 限制单个IP在一定时间内访问次数
    前端常用js插件
  • 原文地址:https://www.cnblogs.com/itdef/p/11418298.html
Copyright © 2011-2022 走看看