eventl.h

来自「一本全面剖析C++数据结构算法的书籍」· C头文件 代码 · 共 42 行

H
42
字号
// event queue for machine shop simulation#ifndef EventList_#define EventList_class EventList {   public:      EventList(int m, long BigT);      ~EventList(){delete [] FinishTime;}   	void NextEvent(int& p, long& t);      long NextEvent(int p) {return FinishTime[p];}      void SetFinishTime(int p, long t)              {FinishTime[p] = t;}   private:      long *FinishTime; // finish time array      int NumMachines;  // number of machines in shop};EventList::EventList(int m, long BigT){// Initialize finish times for m machines.   if (m < 1) throw BadInitializers();   FinishTime = new long [m+1];   NumMachines = m;   // all machines idle, initialize with   // large finish time   for (int i = 1; i <= m; i++)      FinishTime[i] = BigT;}void EventList::NextEvent(int& p, long& t){// Return machine and time for next event.   // find first machine to finish, this is   // machine with smallest finish time   p = 1;   t = FinishTime[1];   for (int i = 2; i <= NumMachines; i++)      if (FinishTime[i] < t) {// i finishes earlier         p = i;         t = FinishTime[i];}}#endif

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?