代码随想录 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. 软件构建

相关推荐
思麟呀7 小时前
应用层协议HTTP
linux·服务器·网络·c++·网络协议·http
Tina学编程7 小时前
[HOT 100]今日一练------划分字母区间
算法·hot 100
RTC老炮7 小时前
RaptorQ前向纠错算法架构分析
网络·算法·架构·webrtc
故事和你917 小时前
洛谷-数据结构1-1-线性表2
开发语言·数据结构·算法·动态规划·图论
小徐不徐说7 小时前
面试C++易错点总结
开发语言·c++·面试·职场和发展·程序设计·工作
m0_555762907 小时前
从原始信号到IQ图的数学公式推导
算法
靠沿7 小时前
【递归、搜索与回溯算法】专题四——综合练习
算法·深度优先
北顾笙9807 小时前
day26-数据结构力扣
数据结构·算法·leetcode
德索精密工业-胡工7 小时前
M12连接器的增强技术:在高电磁干扰的车间里它是如何“活下来”的?
算法
ZenosDoron7 小时前
函数形参传数组
java·jvm·算法