洛谷 P2278 HNOI2003 作業系統

2021-07-26 03:23:53 字數 1149 閱讀 5712

寫乙個程式來模擬作業系統的程序排程。假設該系統只有乙個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 6

3 19

5 30

6 32

8 34

4 35

7 40

2 42

一眼就是堆的題,放到stl的優先佇列裡模擬一下。t代表時間,每次讀入需要把當前的程序掛完或到當前讀入程序的開始時間,讀完以後就直接依次彈出。很簡單的模擬,用的優先佇列維護,和手寫堆效率沒法比。。。(個人感覺思想比樓下的簡單)

ps注意手寫min,用iostream的常數太大

#include 

struct note

; bool operator < (const note &a) const

};std::priority_queue q;

int id,pr,re,ti;

int t;

int main()

q.push(note(id,re,ti,pr));

}while (!q.empty())

}

洛谷 P2278 HNOI2003 作業系統

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

洛谷P2278 HNOI2003 作業系統

主要思路 模擬,優先佇列 考慮維護乙個優先佇列,過載小於號,對於這個小於號的定義為如果兩個工作等級相同,那麼按照到達時間先後排序,否則按照工作等級高低排序 然後每輸入乙個工作,考慮在這個工作執行之前所有可以被完成的工作,當已經不存在可以被完成的工作但佇列非空的時候,表示目前的工作只能被完成一部分,那...

P2278 HNOI2003 作業系統

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