批处理作业调度(回溯法)

本文探讨了批处理作业调度问题,通过回溯法寻找最小完成时间的作业顺序。具体介绍了一个包含n个作业的场景,每个作业需在两台机器上依次处理。算法设计中,定义了数据结构和关键变量,并给出了一组示例来解释算法工作原理。最终,通过递归的回溯搜索找到最优调度方案,例如作业1、3、2的顺序,其总处理时间为18。
摘要由CSDN通过智能技术生成

1.问题描述:

  给定n个作业,集合J=(J1,J2,J3)。每一个作业Ji都有两项任务分别在2台机器上完成。每个作业必须先有机器1处理,然后再由机器2处理。作业Ji需要机器j的处理时间为tji。对于一个确定的作业调度,设Fji是作业i在机器j上完成处理时间。则所有作业在机器2上完成处理时间和,称为该作业调度的完成时间和。即F12+F22+F32+.....+Fn2

简单描述:

  对于给定的n个作业,指定最佳作业调度方案,使其完成时间和达到最小。
2.算法设计:

------从n个作业中找出有最小完成时间和的作业调度,所以批处理作业调度问题的解空间是一棵排列树。

  类Flowshop的数据成员记录解空间的结点信息,M输入作业时间,bestf记录当前最小完成时间和,数组bestx记录相应的当前最佳作业调度。

数组x[i],bestx[i],二维数组m[j][i];

数组x记录当前调度;

bestx记录当前最优调度;

初始时,x[i]=i ;      bestx[i]=∞;     (i=0,1,......,n)

二维数组m记录各作业分别在两台机器上的处理时间;

m[j][i]表示在第i台机器上作业j的处理时间


变量f1,f2,cf,bestf;

f1记录作业在第一台机器上的完成时间和;

f2记录作业在第一台机器上的完成时间和;

cf记录当前在第二台机器上的完成时间和;

bestf

  • 7
    点赞
  • 55
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值