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

相关推荐
血小板要健康14 小时前
189.轮转数组,力扣
数据结构·算法·leetcode
项目申报小狂人14 小时前
CEC2024获胜算法mLSHADE-RL:具有重新启动和本地搜索机制的多操作员集成LSHADE
算法
Faker66363aaa14 小时前
YOLOv26人脸检测算法实现与优化_2
算法·yolo
蒟蒻的贤14 小时前
set和map
算法
格林威14 小时前
Baumer相机铁轨表面裂纹巡检:提升铁路安全监测能力的 7 个关键技术,附 OpenCV+Halcon 实战代码!
人工智能·数码相机·opencv·算法·安全·计算机视觉·分类
m0_6860416114 小时前
C++中的装饰器模式变体
开发语言·c++·算法
web小白成长日记14 小时前
从一道面试题看算法思维:最小栈(Min Stack)的从 O(N) 到 O(1) 进化之路
算法
Remember_99314 小时前
网络编程套接字深度解析:从理论到实践的完整指南
网络·算法·http·https·udp·哈希算法·p2p
钮钴禄·爱因斯晨14 小时前
机器学习(三):聚焦KNN算法距离度量、特征预处理与超参数选择
人工智能·算法·机器学习
星火开发设计14 小时前
动态内存分配:new 与 delete 的基本用法
开发语言·c++·算法·内存·delete·知识·new