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

暂无。。。

相关推荐
朝阳同学6 分钟前
C++中高精度运算问题
开发语言·c++
风清扬雨8 分钟前
计算机视觉中的基于网格的卷绕算法全解析
人工智能·算法·计算机视觉
对方正在长头发丿9 分钟前
棋盘问题(DFS)
数据结构·c++·算法·蓝桥杯·深度优先
@蓝莓果粒茶11 分钟前
LeetCode第132题_分割回文串II
开发语言·算法·leetcode·职场和发展·c#·.net·linq
汐汐咯42 分钟前
编程题学习
c++
云闲不收1 小时前
垃圾回收——三色标记法(golang使用)
jvm·算法·golang
孞㐑¥1 小时前
C++之红黑树
开发语言·c++·经验分享·笔记
菜鸟江多多1 小时前
32x32热成像高斯滤波图像处理
图像处理·单片机·算法
阳洞洞1 小时前
二叉树的层序遍历
数据结构·算法·leetcode·二叉树遍历·广度优先搜索
今天也要早睡早起1 小时前
代码随想录算法训练营Day32| 完全背包问题(二维数组 & 滚动数组)、LeetCode 518 零钱兑换 II、377 组合总数 IV、爬楼梯(进阶)
数据结构·c++·算法·leetcode·动态规划·完全背包