流水作业的Johnson 法则

题目:
某印刷厂有6项任务,J1,J2,J3,J4,J5,J6,在印刷车间各需时间为3,12,5,2,9,11,在装订车间需8,10,9,6,3,1。安排这些任务的加工次序。
在这里插入图片描述
求解:

(1) 将{a1,a2,a3,…an, b1,b2,…bn}排成非递减序列;
(2) 依次从序列中抽出最小元素 m,如果m = aj。且作业 j还设有排入调度表,则把作业安排在调度表可达的最左面一项定位上。(n个作业的调度有n项。开始全部为空。)如果m = bj,且作业j未排入,则把作业j排在最右项上。如果作业j 已排入,则取序列下一个最小元素。
(3) 继续(1)、(2),直到元素取完为止。

过程:

作业号处理机1时间处理机2时间
J21210
J6111
J593
J359
J138
J426
作业号处理机2时间处理机1时间
J21012
J395
J183
J462
J539
J6111

依次取出
J4 J6
J4 J1 J5 J6
J4 J1 J3 J2 J5 J6

得出最优解

代码:

#include<bits/stdc++.h>
using namespace std;
int a[6]= {2,4,3,6,1}; //在M1上的作业时间
int b[6]= {5,2,3,1,7}; //在M2上的作业时间
int n=5;
int best[100];//记录最优
struct node {
	int time;//用来排序
	int  index;//标记存储的作业号
	int flag;//进行排序,1:非减序;0:非增序
};
bool cmp(struct node a,struct node b) {
	return a.time<b.time;
}
int main() {

	struct node c[100];
	for(int i=0; i<n; i++) {
		c[i].time=a[i]<b[i]?a[i]:b[i];
		c[i].index=i;
		if(a[i]<=b[i]) {
			c[i].flag=1;
		} else {
			c[i].flag=0;
		}
	}
	sort(c,c+n,cmp);
	int j=0;
	int k=n-1;
	for(int i=0; i<n; i++) {
		if(c[i].flag==1) {
			best[j++]=c[i].index;
		} else {
			best[k--]=c[i].index;
		}
	}

	int m1=a[best[0]];//m1上的作业时间
	int end=m1+b[best[0]];
	for(int i=1; i<n; i++) {//其他作业
		m1+=a[best[i]];
		end=m1>end?m1+b[best[i]]:end+b[best[i]];
	}
	cout << "最优调度时间:"<<end << endl<<endl;
	cout << "最优调度顺序" << endl;
	for(int i=0; i<n; i++) {
		cout << best[i]+1 << " " ;
	}
	cout << endl;

	return 0;
}
// 最短的调度时间 19
// 调度顺序3 1 2 0 4
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值