ZBLOG

在此基础上给出路径的各节点

在上述示例代码中,我们可以根据关键路径算法的逻辑,添加一些额外的代码来输出关键路径上的各个节点。

void findCriticalPath() {
    vector<int> inDegree(numVertices, 0);
    
    for (int u = 0; u < numVertices; ++u) {
        for (auto& edge : adjacencyList[u]) {
            int v = edge.first;
            ++inDegree[v];
        }
    }
    
    vector<int> startTime(numVertices, 0);
    vector<int> endTime(numVertices, 0);
    
    queue<int> q;
    
    for (int u = 0; u < numVertices; ++u) {
        if (inDegree[u] == 0) {
            q.push(u);
        }
    }
    
    while (!q.empty()) {
        int u = q.front();
        q.pop();
        
        for (auto& edge : adjacencyList[u]) {
            int v = edge.first;
            int weight = edge.second;
            
            inDegree[v]--;
            
            startTime[v] = max(startTime[v], startTime[u] + weight);
            
            if (inDegree[v] == 0) {
                q.push(v);
            }
        }
        
        endTime[u] = startTime[u];
    }
    
    int criticalPathLength = *max_element(endTime.begin(), endTime.end());
    
    cout << "Critical path length: " << criticalPathLength << endl;
    
    // 输出关键路径上的节点
    cout << "Critical path nodes: ";
    
    int currentNode = -1;
    
    for (int i = 0; i < numVertices; ++i) {
        if (endTime[i] == criticalPathLength && currentNode == -1) {
            currentNode = i;
            cout << currentNode << " ";
        } else if (endTime[i] == criticalPathLength && startTime[i] == startTime[currentNode]) {
            currentNode = i;
            cout << currentNode << " ";
        }
    }
    
    cout << endl;
}

findCriticalPath()函数中,我们增加了一段代码来输出关键路径上的各个节点。这里使用了一个currentNode变量来跟踪当前节点,并根据结束时间和开始时间进行判断,找到关键路径上的节点并输出。

这样,在调用graph.findCriticalPath()之后,除了输出关键路径长度外,还会输出关键路径上的各个节点。


内容由零声教学AI助手提供,问题来源于学员提问

本站部分文章来源于网络,版权归原作者所有,如有侵权请联系站长删除。
转载请注明出处:https://golang.0voice.com/?id=16069

分享:
扫描分享到社交APP
上一篇
下一篇
发表列表
游客 游客
此处应有掌声~
评论列表

还没有评论,快来说点什么吧~

联系我们

在线咨询: 点击这里给我发消息

微信号:3007537140

上班时间: 10:30-22:30

关注我们
x

注册

已经有帐号?