当前位置: 首页>編程日記>正文

[算法]详解关键路径算法

[算法]详解关键路径算法

详解关键路径算法

#include <iostream>
#include <vector>
using namespace std;
int eventsSize, activitiesSize;
int activitiesCostTimes[100][100];
pair<int, int> activities[100];
int eventEarlyBegin[100], eventLatestBegin[100];
int activityEarlyBegin[100], activityLatestBegin[100];void init() {memset(eventLatestBegin, 0, sizeof(eventLatestBegin));memset(eventEarlyBegin, 0, sizeof(eventEarlyBegin));memset(activityEarlyBegin, 0, sizeof(eventEarlyBegin));memset(activityLatestBegin, 0, sizeof(activityLatestBegin));
}void computeEventEarliestBegin() {eventEarlyBegin[1] = 0;int maxTimes;for (int i = 2; i <= eventsSize; ++i) {maxTimes = INT_MIN;for (int j = 1; j <= eventsSize; ++j) {if (activitiesCostTimes[j][i] != 0) {maxTimes = max(maxTimes, eventEarlyBegin[j] +activitiesCostTimes[j][i]);}}eventEarlyBegin[i] = maxTimes;}
}void computeEventLatestBegin() {eventLatestBegin[eventsSize] = eventEarlyBegin[eventsSize];int minCostTimes;for (int i = eventsSize - 1; i >= 1; --i) {minCostTimes = INT_MAX;for (int j = i; j <= eventsSize; ++j) {if (activitiesCostTimes[i][j] != 0) {minCostTimes = min(minCostTimes, eventLatestBegin[j] -activitiesCostTimes[i][j]);}}eventLatestBegin[i] = minCostTimes;}
}void computeActivityEarlyBegin() {for (int i = 1; i <= activitiesSize; ++i) {activityEarlyBegin[i] = eventEarlyBegin[activities[i - 1].first];}
}void computeActivityLatestBegin() {for (int i = 1; i <= activitiesSize; ++i) {activityLatestBegin[i] = eventLatestBegin[activities[i - 1].second] -activitiesCostTimes[activities[i - 1].first][activities[i -1].second];}
}vector<int> criticalPath() {init();computeEventEarliestBegin();computeEventLatestBegin();computeActivityEarlyBegin();computeActivityLatestBegin();vector<int> vec;for (int i = 1; i <= activitiesSize; ++i) {if (activityEarlyBegin[i] == activityLatestBegin[i]) {vec.push_back(i);}}return vec;
}int main() {cin >> eventsSize >> activitiesSize;int start, end, last;for (int i = 0; i < activitiesSize; ++i) {cin >> start >> end >> last;activitiesCostTimes[start][end] = last;activities[i] = make_pair(start, end);}vector<int> ans = criticalPath();for (int j = 0; j < ans.size(); ++j) {cout << ans[j] << " ";}cout << endl;return 0;
}

测试样例:

9 11
1 2 6
1 3 4
1 4 5
2 5 1
3 5 1
4 6 2
5 7 7
5 8 5
6 8 4
7 9 2
8 9 4

详情见:

关键路径MBA
关键路径


https://www.fengoutiyan.com/post/13994.html

相关文章:

  • 如何计算关键路径
  • 路径选择算法
  • 关键路径方法
  • 关键路径计算
  • 关键路径怎么找
  • 关键路径分析
  • 关键路径算法
  • 关键路径算法图示
  • 鏡像模式如何設置在哪,圖片鏡像操作
  • 什么軟件可以把圖片鏡像翻轉,C#圖片處理 解決左右鏡像相反(旋轉圖片)
  • 手機照片鏡像翻轉,C#圖像鏡像
  • 視頻鏡像翻轉軟件,python圖片鏡像翻轉_python中鏡像實現方法
  • 什么軟件可以把圖片鏡像翻轉,利用PS實現圖片的鏡像處理
  • 照片鏡像翻轉app,java實現圖片鏡像翻轉
  • 什么軟件可以把圖片鏡像翻轉,python圖片鏡像翻轉_python圖像處理之鏡像實現方法
  • matlab下載,matlab如何鏡像處理圖片,matlab實現圖像鏡像
  • 圖片鏡像翻轉,MATLAB:鏡像圖片
  • 鏡像翻轉圖片的軟件,圖像處理:實現圖片鏡像(基于python)
  • canvas可畫,JavaScript - canvas - 鏡像圖片
  • 圖片鏡像翻轉,UGUI優化:使用鏡像圖片
  • Codeforces,CodeForces 1253C
  • MySQL下載安裝,Mysql ERROR: 1253 解決方法
  • 勝利大逃亡英雄逃亡方案,HDU - 1253 勝利大逃亡 BFS
  • 大一c語言期末考試試題及答案匯總,電大計算機C語言1253,1253《C語言程序設計》電大期末精彩試題及其問題詳解
  • lu求解線性方程組,P1253 [yLOI2018] 扶蘇的問題 (線段樹)
  • c語言程序設計基礎題庫,1253號C語言程序設計試題,2016年1月試卷號1253C語言程序設計A.pdf
  • 信奧賽一本通官網,【信奧賽一本通】1253:抓住那頭牛(詳細代碼)
  • c語言程序設計1253,1253c語言程序設計a(2010年1月)
  • 勝利大逃亡英雄逃亡方案,BFS——1253 勝利大逃亡
  • 直流電壓測量模塊,IM1253B交直流電能計量模塊(艾銳達光電)
  • c語言程序設計第三版課后答案,【渝粵題庫】國家開放大學2021春1253C語言程序設計答案
  • 18轉換為二進制,1253. 將數字轉換為16進制
  • light-emitting diode,LightOJ-1253 Misere Nim
  • masterroyale魔改版,1253 Dungeon Master
  • codeformer官網中文版,codeforces.1253 B
  • c語言程序設計考研真題及答案,2020C語言程序設計1253,1253計算機科學與技術專業C語言程序設計A科目2020年09月國家開 放大學(中央廣播電視大學)
  • c語言程序設計基礎題庫,1253本科2016c語言程序設計試題,1253電大《C語言程序設計A》試題和答案200901
  • 肇事逃逸車輛無法聯系到車主怎么辦,1253尋找肇事司機