⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 sched2.cpp

📁 数据结构c++语言描述 Borland C++实现
💻 CPP
字号:


#include <iostream.h>
#include "minheap.h"
#include "task2.h"

void main(void)
{// Output a maximum selection of tasks that can be done
 // on a single machine.

   // input the number of tasks
   int n;  // number of tasks
   cout << "Enter the number of tasks" << endl;
   cin >> n;
   if (n < 1) {cout << "Must be more than 0" << endl;
               exit(1);}

   // input and store the n tasks in a task array
   Task *t = new Task [n+1];
   for (int i = 1; i <= n; i++) {
      cout << "Enter the start and finish time of task "
           << i << endl;
      cin >> t[i].start >> t[i].finish;
      if (t[i].start < 0 || t[i].finish <= 0
          || t[i].start >= t[i].finish) {
          cout << "Bad start and/or finish time"
               << endl;
          exit(1);
          }
      t[i].ID = i;
      }

      // initialize a min heap with n tasks
      MinHeap<Task> H(1);
      H.Initialize(t,n,n);

      // select tasks
      cout << "The selected tasks are ";
      int avail = 0;  // time machine gets free
      for (int i = 1; i <= n; i++) {
         // get task with least finish time
         Task w;
         H.DeleteMin(w);
         if (w.start >= avail) {
             // select the task
             cout << w.ID << " ";
             avail = w.finish;
             }
         }  
}

⌨️ 快捷键说明

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