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

相关推荐
qq_416018723 分钟前
C++与机器学习框架
开发语言·c++·算法
左左右右左右摇晃5 分钟前
数据结构——红黑树
算法
CoovallyAIHub10 分钟前
传感器数据相互矛盾时,无人机蜂群如何做出可靠的管道泄漏检测决策?
算法·架构·无人机
CoovallyAIHub12 分钟前
Claude Code Review:多 Agent 自动审查 PR,代码产出翻倍后谁来把关?
算法·架构·github
jyan_敬言30 分钟前
【算法】高精度算法(加减乘除)
c语言·开发语言·c++·笔记·算法
树獭叔叔35 分钟前
内存价格被Google打下来了?: TurboQuant对KVCache的量化
算法·aigc·openai
旖-旎38 分钟前
前缀和(矩阵区域和)(8)
c++·算法·leetcode·前缀和·动态规划
Vect__40 分钟前
基于CSAPP深刻理解编译链接过程
linux·c++
月落归舟1 小时前
排序算法---(一)
数据结构·算法·排序算法
liuyao_xianhui1 小时前
优选算法_翻转链表_头插法_C++
开发语言·数据结构·c++·算法·leetcode·链表·动态规划