BZOJ1216 作業系統(堆,模擬)

2022-03-20 09:04:39 字數 1148 閱讀 7644

寫乙個程式來模擬作業系統的程序排程。假設該系統只有乙個cpu,每乙個程序的到達時間,執行時間和執行優先順序都是已知的。其中執行優先順序用自然數表示,數字越大,則優先順序越高。

如果乙個程序到達的時候cpu是空閒的,則它會一直占用cpu直到該程序結束。除非在這個過程中,有乙個比它優先順序高的程序要執行。在這種情況下,這個新的(優先順序更高的)程序會占用cpu,而老的只有等待。

如果乙個程序到達時,cpu正在處理乙個比它優先順序高或優先順序相同的程序,則這個(新到達的)程序必須等待。

一旦cpu空閒,如果此時有程序在等待,則選擇優先順序最高的先執行。如果有多個優先順序最高的程序,則選擇到達時間最早的。

輸入格式:

輸入包含若干行,每一行有四個自然數(均不超過10^8),分別是程序號,到達時間,執行時間和優先順序。不同程序有不同的編號,不會有兩個相同優先順序的程序同時到達。輸入資料已經按到達時間從小到大排序。輸入資料保證在任何時候,等待佇列中的程序不超過15000個。

輸出格式:

按照程序結束的時間輸出每個程序的程序號和結束時間。

1 1 5 3

2 10 5 1

3 12 7 2

4 20 2 3

5 21 9 4

6 22 2 4

7 23 5 2

8 24 2 4

1 63 19

5 30

6 32

8 34

4 35

7 40

2 42

大模擬+優先佇列(堆,如果你願意手寫)

依照題意建立乙個優先佇列即可

維護一下時間,

記得最後搞完讀入之後要把堆中的所有元素也給搞出去

#include#include#include#include#include#include#include#include#include#includeusing namespace std;

struct work

r;inline bool operator<(work a,work b)

priority_queueq;

int main()

else

}q.push(r);

} }while(!q.empty())

return 0;

}

BZOJ1216 作業系統(堆,模擬)

寫乙個程式來模擬作業系統的程序排程。假設該系統只有乙個cpu,每乙個程序的到達時間,執行時間和執行優先順序都是已知的。其中執行優先順序用自然數表示,數字越大,則優先順序越高。如果乙個程序到達的時候cpu是空閒的,則它會一直占用cpu直到該程序結束。除非在這個過程中,有乙個比它優先順序高的程序要執行。...

bzoj1216 作業系統 優先佇列模擬

time limit 10 sec memory limit 162 mb submit 1172 solved 649 submit status discuss 寫乙個程式來模擬作業系統的程序排程。假設該系統只有乙個cpu,每乙個程序的到達時間,執行時間和執行優先順序都是已知的。其中執行優先順序...

bzoj1216 堆,呵呵的模擬

就是堆的應用,實現的時候會有點奇怪的技巧 now作為當前時間,順序列舉每乙個程序的到來,注意在每乙個程序來之前要處理完成前面的所有程序!注意放乙個哨兵元素lev為 inf,rest為inf,防止bug,include include include include include includeus...