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 工程化

暂无。。。

相关推荐
小森77674 分钟前
(七)深度学习---神经网络原理与实现
人工智能·深度学习·神经网络·算法
二年级程序员16 分钟前
C++的历史与发展
c++
迷茫不知归路22 分钟前
操作系统实验习题解析 上篇
c++·算法·操作系统·实验课设
一个尚在学习的计算机小白23 分钟前
文件相关操作
c++
愚润求学42 分钟前
【递归、搜索与回溯】专题一:递归(二)
c++·笔记·算法·leetcode
h汉堡43 分钟前
C/C++内存管理
java·c语言·开发语言·c++·学习
大鱼BIGFISH1 小时前
C++ 字符格式化输出
c++·字符格式化输出
水水沝淼㵘1 小时前
嵌入式开发学习日志(数据结构--顺序结构单链表)Day19
linux·服务器·c语言·数据结构·学习·算法·排序算法
愚润求学1 小时前
【Linux】基础 IO(一)
linux·运维·服务器·开发语言·c++·笔记
June`2 小时前
专题四:综合练习( 找出所有子集的异或总和再求和)
c++·算法·深度优先·剪枝