BZOJ 1216 HNOI2003 作業系統

2021-08-01 16:33:19 字數 1548 閱讀 7768

time limit: 10 sec  memory limit: 162 mb

submit: 886  solved: 492

[submit][status][discuss]

寫乙個程式來模擬作業系統的程序排程。假設該系統只有乙個cpu,每乙個程序的到達時間,執行時間和執行優先順序都是已知的。其中執行優先順序用自然數表示,數字越大,則優先順序越高。如果乙個程序到達的時候cpu是空閒的,則它會一直占用cpu直到該程序結束。除非在這個過程中,有乙個比它優先順序高的程序要執行。在這種情況下,這個新的(優先順序更高的)程序會占用cpu,而老的只有等待。如果乙個程序到達時,cpu正在處理乙個比它優先順序高或優先順序相同的程序,則這個(新到達的)程序必須等待。一旦cpu空閒,如果此時有程序在等待,則選擇優先順序最高的先執行。如果有多個優先順序最高的程序,則選擇到達時間最早的。

輸入檔案包含若干行,每一行有四個自然數(均不超過108),分別是程序號,到達時間,執行時間和優先順序。不同程序有不同的編號,不會有兩個相同優先順序的程序同時到達。輸入資料已經按到達時間從小到大排序。輸入資料保證在任何時候,等待佇列中的程序不超過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#include#include#include#include#includeusing namespace std;

inline int read()

while(ch<='9'&&ch>='0')

return f*x;

}const int n=20000;

struct proe;

bool operator <(pro a,pro b)

priority_queueq;

mapmp;

int main()

else

}q.push(e);

} }while(!q.empty())

return 0;

} /*

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

*/

bzoj 1216 HNOI2003 作業系統

一開始想的用heap維護一下,但是發現輸出不好搞,而且維護兩個值的heap好像不怎麼會做,然後學習了一發優先佇列,挺好用的,直接模擬就好了,用優先佇列維護一下優先順序和到達時間就好了。include include include include include define fo i,a,b fo...

bzoj1216 HNOI2003 作業系統

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

BZOJ1216 HNOI2003 作業系統

我對模擬的理解 題目傳送門 不茲磁多執行緒的系統不是好系統 對於每個程序,我們都記錄下關於它的五個引數 程序號,起始時間,持續時間,終結時間以及優先順序。按照題意,優先順序越大越應優先執行,同優先順序的比起始時間,用堆來維護已經進來排隊的程序,然後按題意模擬即可。因為學長說想要 noi 金牌,堆肯定...