多机调度问题(贪心法)

题目: 

设有n个独立的作业{1, 2, …, n},由m台相同的机器{M1, M2, …, Mm}进行加工处理,作业i所需的处理时间为ti(1≤i≤n),每个作业均可在任何一台机器上加工处理,但不可间断、拆分。多机调度问题要求给出一种作业调度方案,使所给的n个作业在尽可能短的时间内由m台机器加工处理完成。

 

 

伪代码为:

将数组t[n]由大到小排序,对应的作业序号存储在数组p[n]中;

 2.将数组d[m]初始化为0;

 3.for (i=1; i<=m; i++)

      3.1 S[i]={p[i]};   //将m个作业分配给m个机器

      3.2 d[i]=t[i];   

 4.  for (i=m+1; i<=n; i++)

      4.1  j=数组d[m]中最小值对应的下标;  //j为最先空闲的机器序号

      4.2  S[j]=S[j]+{p[i]};   //将作业i分配给最先空闲的机器j

      4.3  d[j]=d[j]+t[i];      //机器j将在d[j]后空闲

 

 #include <iostream>

 #include <cstdio>

 #include <algorithm>

 using namespace std;

 struct Data

  {

      int data;

     int index;

  };

 Data t[100];

 Data d[100];

 bool cmp(Data a,Data b){  //实现结构体数组按照data项进行从大到小排序

  return a.data > b.data ;

 }   

 int  sortmin(Data d[], int n){

  int i,indexs=0;

  for(i=0; i<n; i++){

  if(d[i].data < d[indexs].data )

  indexs=i;

  }

  return indexs;

 }

 void duoji(Data t[],  int n, int m){

  int i,j;

  int S[100][100], p[100];

  int h[100];

  Data d[100];

  memset(h,0,sizeof(h));

 

  sort(t,t+n,cmp);

  cout<<endl<<"排序后的作业序号为:";

  for(i=0; i<n; i++){

  p[i]=t[i].index;  //1、将t[]排序后,按照从大到小将作业号存储在p[]数组中

     cout<<p[i]+1<<" ";

  }

  cout<<endl;

  for(i=0; i<m; i++){  //2、初始化d[]数组,d[]数组记录的是m台机器的空闲时间

  d[i].data=0;

  d[i].index=i;

  }

 

  if(n<m){    //A、当作业数n < 机器数m的情况

  for(i=0; i<n; i++){  //记录第一次的分配

  S[i][0]=p[i] ;   

  d[i].data = t[i].data ;

  cout<<"第"<<i<<"台机器处理的作业号为:"<<S[i][0]<<";  "

  <<"所需时间分别为: "<<d[i].data<<endl;

  }

 }

  else{  //B、当作业数n > 机器数m的情况

  for(i=0; i<m; i++){  //记录第一次的分配

  S[i][0]=p[i] ;   

  d[i].data = t[i].data ;

  cout<<"第"<<i+1<<"台机器处理的作业号为:"<<S[i][0]<<";  "

  <<"所需时间为: "<<d[i].data<<endl;

  //cout<<S[i][0]<<": "<<d[i].data<<endl;

  }

  for(i=m; i<n; i++){

  int j=sortmin(d,m);

  cout<<"下一次为机器 "<<j+1<<" 来处理作业";  //j验证第一次是正确的

  S[j][++h[j]]=p[i];

  cout<<"  ,并且此次机器"<<j+1<<"处理的作业为:"<<S[j][h[j]]+1<<" ";

  d[j].data += t[i].data;

  cout<<endl;

  }

 }

 }

 int main()

 {

     int i,n,m;

     cout<<"输入作业个数n和机器个数m: ";

     cin>>n>>m;

     cout<<"输入完成各作业所需要的处理时间:"<<endl;

     for(i=0; i<n; i++){

     cin>>t[i].data;

     t[i].index=i;

     }

     cout<<endl<<"各机器所处理的作业情况为:"<<endl;

     cout<<endl;

     duoji( t, n,  m);       

     return 0;

 }


输出结果为:


 

输入作业个数n和机器个数m: 7 3

 输入完成各作业所需要的处理时间:

 2 14 4 16 6 5 3

 

 各机器所处理的作业情况为:

 

 

 排序后的作业序号为:4 2 5 6 3 7 1

 第1台机器处理的作业号为:3;  所需时间为: 16

 第2台机器处理的作业号为:1;  所需时间为: 14

 第3台机器处理的作业号为:4;  所需时间为: 6

 下一次为机器 3 来处理作业  ,并且此次机器3处理的作业为:6

 下一次为机器 3 来处理作业  ,并且此次机器3处理的作业为:3

 下一次为机器 2 来处理作业  ,并且此次机器2处理的作业为:7

 下一次为机器 3 来处理作业  ,并且此次机器3处理的作业为:1

 

 

 

              Press any key to continue


 

  • 4
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值