题目:
设有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