青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

lzm

who dare win.
posts - 14, comments - 29, trackbacks - 0, articles - 0

Critical Path 關鍵路徑

Posted on 2009-04-09 23:02 lzmagic 閱讀(1911) 評論(0)  編輯 收藏 引用 所屬分類: Algorithm
/**
 * CRITICALPATH(簡單版) 關鍵路徑 
 * 輸入:無環圖g。 
 * 輸出:(1)各點最早完成時間ec; 
 *       (2)各點最晚完成時間lc; 
 *       (3)關鍵路徑prev。 
 * 結構:圖g用鄰接矩陣表示
 * 算法:拓撲排序,動態規劃(DP) 
 * 復雜度:O(|V|^2) 
 
*/

#include 
<iostream>
#include 
<string>
#include 
<vector>
#include 
<deque>
#include 
<list>
#include 
<stack>
#include 
<queue>
#include 
<iterator>
#include 
<algorithm>
#include 
<numeric>
#include 
<functional>
#include 
<climits>
using namespace std;

int n;                        // n :頂點個數 
vector<vector<int> > g;        // g :圖(graph)(用鄰接矩陣(adjacent matrix)表示) 

vector
<int> seq;            // seq :拓撲序列(sequence) 

bool TopSort()        // 拓撲排序 
{
    vector
<int> inc(n, 0);     
    
for (int i = 0; i < n; ++i)
        
for (int j = 0; j < n; ++j)
             
if (g[i][j] < INT_MAX) ++inc[j]; // 計算每個頂點的入度, 
    queue<int> que;
    
for (int j = 0; j < n; ++j)
        
if (inc[j] == 0) que.push(j); // 如果頂點的入度為0,入隊。
    int seqc = 0;
    seq.resize(n);
    
while (!que.empty())     // 如果隊列que非空,
    {
        
int v = que.front(); que.pop();     
        seq[seqc
++= v;      // 頂點v出隊,放入seq中,
        for (int w = 0; w < n; ++w)     // 遍歷所有v指向的頂點w,
            if (g[v][w] < INT_MAX)
                
if (--inc[w] == 0) que.push(w); // 調整w的入度,如果w的入度為0,入隊。 
    }

    
return seqc == n; // 如果seq已處理頂點數為n,存在拓撲排序,否則存在回路。
}


vector
<int> ec;                // ec : 最早完成時間(early complete time) 
vector<int> lc;                // lc : 最晚完成時間(late complete time) 
vector<int> cp;                // cp : 關鍵路徑(critical path)

void CriticalPath()    // 關鍵路徑 
{
    
// 最早完成時間:ec[0] = 0;
    
//               ec[v] = max(ec[u] + g[u][v])。 
    ec.assign(n, INT_MIN);  ec[seq[0]] = 0;
    
for (int i = 0; i < n - 1++i)
        
for (int v = 0; v < n; ++v)
            
if (g[seq[i]][v] < INT_MAX)
                ec[v] 
= max(ec[v], ec[seq[i]] + g[seq[i]][v]);
    
// 最晚完成時間:lc[n - 1] = ec[n - 1];
    
//               lc[u] = min(lc[v] - g[u][v])。 
    lc.assign(n, INT_MAX);    lc[seq[n - 1]] = ec[seq[n - 1]]; 
    
for (int j = n - 1; j > 0--j)
        
for (int u = 0; u < n; ++u)
            
if (g[u][seq[j]] < INT_MAX)
                lc[u] 
= min(lc[u], lc[seq[j]] - g[u][seq[j]]);
    
// 關鍵路徑:cp[0] = seq[0]; 
    
//           if(松弛時間slack(u, v) = lc[v] - ec[u] - g[u][v]為零) 
    
//             { u為關鍵路徑點;如果u為seq[n - 1],結束。} 
    cp.clear(); cp.push_back(seq[0]); 
    
for (int i = 0; i < n - 1++i)
    
{
        
for (int v = 0; v < n; ++v)
            
if (g[cp[i]][v] < INT_MAX)
            
{
                
int slack = lc[v] - ec[cp[i]] - g[cp[i]][v];
                
if (slack == 0{ cp.push_back(v); break; }
            }

        
if (cp.back() == seq[n - 1]) break;
    }

}


int main()
{
    n 
= 9;
    g.assign(n, vector
<int>(n, INT_MAX));
    g[
0][1= 6; g[0][2= 4; g[0][3= 5;
    g[
1][4= 1;
    g[
2][4= 1;
    g[
3][5= 2;
    g[
4][6= 9; g[4][7= 7;
    g[
5][7= 4;
    g[
6][8= 2;
    g[
7][8= 4;         
    
    
if (TopSort())
    
{
         copy(seq.begin(), seq.end(), ostream_iterator
<int>(cout, " ")); cout << endl;
         CriticalPath();
         copy(ec.begin(), ec.end(), ostream_iterator
<int>(cout, " ")); cout << endl;
         copy(lc.begin(), lc.end(), ostream_iterator
<int>(cout, " ")); cout << endl;
         copy(cp.begin(), cp.end(), ostream_iterator
<int>(cout, " ")); cout << endl;
    }

    
else
    
{
         cout 
<< "Circles exist." << endl;
    }

    
    system(
"pause");
    
return 0;
}

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            一区二区三区无毛| 亚洲一区日韩在线| 免费在线看一区| 美女啪啪无遮挡免费久久网站| 黄网动漫久久久| 亚洲福利视频三区| 欧美国产另类| 亚洲欧美激情一区| 欧美一区二区三区日韩视频| 国产综合久久久久影院| 欧美肥婆在线| 欧美日韩xxxxx| 久久国产精品免费一区| 久久久噜噜噜久久久| 日韩视频免费观看| 亚洲一区二区3| 影院欧美亚洲| 中日韩男男gay无套| 国产一区二区三区在线观看网站| 免费久久99精品国产| 欧美精品91| 久久久久高清| 欧美区在线播放| 久久精品视频在线观看| 欧美精品免费播放| 久久精彩视频| 欧美区日韩区| 免费一级欧美片在线观看| 欧美人成在线视频| 久久亚洲电影| 国产精品日韩精品欧美精品| 欧美高清视频一二三区| 国产精品亚洲美女av网站| 欧美福利视频| 国产日韩欧美亚洲| av不卡在线看| 日韩午夜电影在线观看| 欧美一区二区三区啪啪| 一区二区三区四区五区视频| 久久婷婷av| 久久精品亚洲热| 欧美午夜视频在线| 亚洲国产视频一区| 亚洲成在线观看| 午夜在线a亚洲v天堂网2018| 在线视频日本亚洲性| 麻豆精品视频在线观看| 久久精品国产一区二区三| 欧美四级在线观看| 亚洲国产精品视频| 亚洲激情自拍| 久久综合狠狠| 老司机久久99久久精品播放免费| 国产精品永久免费视频| 日韩视频一区二区三区| 亚洲精品在线看| 鲁大师成人一区二区三区| 久久影视三级福利片| 国产欧美日本| 午夜久久福利| 久久激情久久| 狠狠色综合网站久久久久久久| 亚洲女人天堂成人av在线| 亚洲综合成人婷婷小说| 欧美日韩综合在线| 在线视频免费在线观看一区二区| 一本色道久久综合亚洲精品婷婷| 欧美www视频| 亚洲精品国产视频| 亚洲视频你懂的| 国产精品国产亚洲精品看不卡15| 一区二区久久久久久| 亚洲一区精品电影| 国产精品视频你懂的| 亚洲欧美日韩国产成人精品影院| 午夜精品视频在线观看一区二区| 国产精品亚洲аv天堂网| 欧美一区二区三区视频免费| 久久久蜜桃一区二区人| 在线不卡免费欧美| 欧美国产日本高清在线| 日韩午夜电影av| 午夜精品影院在线观看| 国产欧美一区二区三区久久| 亚洲欧美视频在线观看视频| 久久亚洲影音av资源网| 亚洲国产日韩欧美在线动漫| 欧美日本高清| 亚洲欧美激情视频| 欧美福利视频在线| 亚洲婷婷国产精品电影人久久| 国产精品色婷婷| 久久综合色88| aa级大片欧美三级| 久久理论片午夜琪琪电影网| 亚洲国产老妈| 国产麻豆视频精品| 免费欧美高清视频| 亚洲在线电影| 亚洲二区免费| 久久高清免费观看| 亚洲靠逼com| 国产欧美一区二区三区在线老狼 | 欧美在线三级| 亚洲激情成人| 国产精品午夜电影| 女女同性女同一区二区三区91| 一区二区三区www| 欧美成人免费全部观看天天性色| 亚洲影院色在线观看免费| 国产最新精品精品你懂的| 欧美精品国产一区| 久久久精品2019中文字幕神马| 日韩视频在线观看国产| 蜜臀a∨国产成人精品| 亚洲欧美日本伦理| 亚洲精品一区二| 国内精品久久久久国产盗摄免费观看完整版| 久久不射中文字幕| 亚洲另类自拍| 亚洲国产精品第一区二区| 国产精品网曝门| 欧美日韩视频一区二区三区| 久久综合给合| 久久久久久色| 久久av一区二区| 亚洲欧美另类在线观看| 99精品欧美一区二区三区 | 亚洲美女中出| 国产视频综合在线| 欧美色中文字幕| 欧美成人午夜剧场免费观看| 欧美中文字幕在线| 亚洲欧美日韩精品| 在线中文字幕一区| 亚洲人成网站精品片在线观看| 老司机67194精品线观看| 久久久久国产精品厨房| 午夜精品视频在线| 欧美一级片一区| 午夜精品免费| 久久国产精品99国产精| 午夜在线一区| 欧美一级欧美一级在线播放| 先锋资源久久| 欧美一区高清| 久久久久久久久久久久久久一区| 欧美一区视频| 久久久www成人免费无遮挡大片| 欧美在线日韩| 久久综合999| 欧美激情综合色| 亚洲人成人一区二区在线观看 | 欧美一区二区三区四区视频| 亚洲欧美韩国| 久久国产精品亚洲va麻豆| 久久久久久网址| 欧美成人福利视频| 亚洲欧洲精品一区二区三区| 亚洲精品乱码久久久久| 99精品福利视频| 亚洲伊人色欲综合网| 欧美有码视频| 欧美a级在线| 国产精品久久网| 国内精品久久久久久影视8| 亚洲国产精品精华液网站| 日韩视频一区二区三区在线播放免费观看| 欧美日韩国产探花| 国产精品久久久一区二区| 国产一区二区剧情av在线| 国产在线播放一区二区三区 | 欧美精品一区二区三区久久久竹菊| 欧美阿v一级看视频| 欧美午夜电影完整版| 韩日在线一区| 一本色道久久综合亚洲精品婷婷| 性欧美精品高清| 欧美福利一区二区| 亚洲一本大道在线| 久久久久国产免费免费| 欧美日韩国产欧美日美国产精品| 国产精品网曝门| 亚洲激情午夜| 久久国产色av| 一本久道久久综合中文字幕| 欧美在线free| 欧美吻胸吃奶大尺度电影| 韩国免费一区| 亚洲制服av| 亚洲国产高清一区二区三区| 亚洲欧美一区二区视频| 欧美成人国产一区二区| 国产日韩欧美一区在线 | 亚洲欧美日本日韩| 亚洲第一精品影视| 久久精品在这里| 国产精品婷婷| 亚洲少妇中出一区| 亚洲电影免费观看高清|