代码随想录 117. 软件构建

117. 软件构建

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;

int main(){
    int n, m;
    cin >> n >> m;
    vector<vector<int>> graph(n, vector<int>(0));
    vector<int> indgree(n, 0);
    vector<int> result;
    for (int i = 0; i < m; i++){
        int b, e;
        cin >> b >> e;
        indgree[e]++;//记录入度
        graph[b].push_back(e);
    }
    for (int count = 0; count < n;){
        int add = 0;
        for (int i = 0; i < n; i++){
            if (indgree[i] == 0){
                indgree[i]--;//入度置-1,避免后续再被处理
                result.push_back(i);
                for (int j : graph[i]){
                    indgree[j]--;//更新入度
                }
                add++;
            }
        }
        if (add == 0){//若一轮后没有节点入度为0,则表示无法处理
            cout << -1 << endl;
            return 0;
        }
        count += add;
    }
    for (int i = 0; i < n; i++){
        cout << result[i];
        if (i != n - 1) cout << " ";
    }
    return 0;
}

笔者觉得这题本质上可以算做一种有访问条件的bfs,条件就是只有入度为0的节点才能被访问,访问后需要对节点的相邻节点入度做更新。当一个节点入度为0,就代表节点代表的文件的前置任务都已经完成,可以被处理,不断寻找入度为0的节点,直到所有节点都访问过,或有未访问的节点但构成有向环,无法处理。

代码随想录 117. 软件构建

相关推荐
凤年徐4 小时前
C++手撕红黑树:从0到200行,拿下STL map底层核心
c++·后端·算法
星河耀银海4 小时前
C++ 模板进阶:特化、萃取与可变参数模板
java·开发语言·c++
Thomas.Sir4 小时前
AI 医疗之罕见病/疑难病辅助诊断系统从算法到实现【表型驱动与知识图谱推理】
人工智能·算法·ai·知识图谱
cccccc语言我来了4 小时前
【C++---unordered_set/map底层封装】个不拘一格的集合。它不似有序集合那般循规蹈矩,而是以一种洒脱不羁的方式,将元素们随意地散落其中。每一个元素都是独一无二的。
开发语言·c++·哈希算法
Zfox_4 小时前
C++ IO流全解析:标准库中的数据处理与文件读写艺术
开发语言·c++
tankeven5 小时前
动态规划专题(03):区间动态规划从原理到实践(未完待续)
c++·算法·动态规划
天若有情6735 小时前
【C++原创开源】formort.h:一行头文件,实现比JS模板字符串更爽的链式拼接+响应式变量
开发语言·javascript·c++·git·github·开源项目·模版字符串
大前端下的小角色5 小时前
UE5.6 Cesium 插件编译踩坑记录(UE 5.6 + MSVC 14.38 + CMake 3.31)
c++
田梓燊6 小时前
2026/4/11 leetcode 3741
数据结构·算法·leetcode
斯内科6 小时前
FFT快速傅里叶变换
算法·fft