acwing算法基础之搜索与图论--有向图的拓扑序列

目录

  • [1 基础知识](#1 基础知识)
  • [2 模板](#2 模板)
  • [3 工程化](#3 工程化)

1 基础知识

拓扑序列:针对有向图而言,该序列内,所有边都是从前指向后的。

如果存在环,那么该图一定不存在拓扑序列。否则,一定存在拓扑序列。

有向图中的入度和出度。

入度为0的结点,可以作为拓扑序列的起点。

求拓扑序列的关键步骤:

  1. 把入度为0的结点插入队列q。
  2. 弹出队头t,遍历队头t的下一个结点,将其入度减1。操作之后,如果其值为0,则插入队列q。
  3. 重复进行步骤2,直至队列q为空。

2 模板

题目1:给出结点数目n和边数m,以及一系列的边,如果此图存在拓扑序列,请输出(输出任意一种拓扑序列即可);否则,输出-1。

cpp 复制代码
#include <iostream>
#include <vector>
#include <queue>

using namespace std;

const int N = 1e5 + 10;
int n, m;
vector<vector<int>> g(N);
vector<int> d(N); //存储每个结点的入度

int main() {
    cin >> n >> m;
    int x, y;
    while (m--) {
        cin >> x >> y;
        //添加x到y的边
        g[x].emplace_back(y);
        d[y]++;
    }
    
    queue<int> q;
    for (int i = 1; i <= n; ++i) {
        if (d[i] == 0) {
            q.push(i);
        }
    }
    
    vector<int> res;
    while (!q.empty()) {
        auto t = q.front();
        res.emplace_back(t); //存入向量res中 
        q.pop();
        
        //t可以走到哪里
        for (auto x : g[t]) {
            //把结点t删除
            d[x]--;
            if (d[x] == 0) {
                q.push(x);
            }
        }
    }
    
    if (res.size() == n) {
        for (int i = 0; i < n; ++i) cout << res[i] << ' ';
        cout << endl;
    } else {
        puts("-1");
    }
    
    return 0;
}

3 工程化

暂无。。。

相关推荐
啊阿狸不会拉杆2 小时前
《机器学习》第六章-强化学习
人工智能·算法·机器学习·ai·机器人·强化学习·ml
Stardep2 小时前
算法入门20——二分查找算法——搜索插入位置
数据结构·算法·leetcode
qwerasda1238522 小时前
青豆质量分类识别_YOLOv5_SPDConv_改进算法_目标检测_深度学习_计算机视觉
算法·计算机视觉·分类
老鼠只爱大米2 小时前
LeetCode经典算法面试题 #141:环形链表(快慢指针、标记节点等多种方法详细解析)
算法·leetcode·链表·快慢指针·floyd算法·环形链表
alanesnape2 小时前
什么是字面量?代码中的常量表示方式解析
算法
王老师青少年编程2 小时前
2024年3月GESP真题及题解(C++八级): 接竹竿
c++·题解·真题·gesp·csp·八级·接竹竿
偷星星的贼112 小时前
C++中的访问者模式实战
开发语言·c++·算法
雾岛听蓝2 小时前
红黑树深度解析:设计原理与实现逻辑
c++
gjxDaniel3 小时前
A+B问题天堂版
c++·算法·字符串·字符数组
M__333 小时前
动态规划进阶:简单多状态模型
c++·算法·动态规划