寫乙個程式來模擬作業系統的程序排程。假設該系統只有乙個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
大模擬+優先佇列(堆,如果你願意手寫)
依照題意建立乙個優先佇列即可
維護一下時間,
記得最後搞完讀入之後要把堆中的所有元素也給搞出去
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
using
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...