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

暂无。。。

相关推荐
fpcc19 分钟前
c++23中的print和println
c++·c++23
星星的月亮叫太阳1 小时前
large-scale-DRL-exploration 代码阅读 总结
python·算法
玉树临风江流儿1 小时前
C++左值、右值、move移动函数
开发语言·c++
王哈哈^_^1 小时前
YOLOv11视觉检测实战:安全距离测算全解析
人工智能·数码相机·算法·yolo·计算机视觉·目标跟踪·视觉检测
..Cherry..1 小时前
Etcd详解(raft算法保证强一致性)
数据库·算法·etcd
商汤万象开发者2 小时前
LazyLLM教程 | 第13讲:RAG+多模态:图片、表格通吃的问答系统
人工智能·科技·算法·开源·多模态
Lee_yayayayaya2 小时前
本原多项式产生m序列的原理
算法
许长安2 小时前
c/c++ static关键字详解
c语言·c++·经验分享·笔记
Murphy_lx2 小时前
C++ thread类
开发语言·c++
月夜的风吹雨3 小时前
【C++ STL 深度剖析】:vector 底层模拟实现与核心陷阱解析
c++·vector·类和对象·visual studio