回溯法(02组合问题)批处理作业调度问题

1.代码

#include<iostream>
#include<windows.h>                            
#include <math.h>   
using namespace std;  

const int n = 3;
int BatchJob(int a[ ], int b[ ], int n);

int main()
{
	int a[n] = {2, 5, 4}, b[n] = {3, 2, 1};
	int bestTime = BatchJob(a, b, 3) ;
	cout<<"最短作业时间是:"<<bestTime<<endl;
	Sleep(80000);
	return 0;
}

int BatchJob(int a[ ], int b[ ], int n)  
{  
	int i, k;
	int x[6], sum1[6], sum2[6];
	int bestTime = 1000;                     //假定最后完成时间不超过1000
	for (i = 1; i <= n; i++)//初始化
	{
		x[i] = -1;
		sum1[i] = 0;
		sum2[i] = 0;
	}
	sum1[0] = 0; sum2[0] = 0;
	k = 1;    



	while (k >= 1)
	{
		x[k] = x[k] + 1;
		while (x[k] < n)
		{
			for (i = 1; i < k; i++)              //1检测作业x[k]是否重复处理
				if (x[i] == x[k]) break;


			if (i == k) {                     //2作业x[k]尚未处理
				sum1[k] = sum1[k-1] + a[x[k]];
				if (sum1[k] > sum2[k-1]) sum2[k] = sum1[k] + b[x[k]];
				else sum2[k] = sum2[k-1] + b[x[k]];
				if (sum2[k] < bestTime) break;
				else x[k] = x[k] + 1;   
			}
			else x[k] = x[k] + 1;             //3作业x[k]已处理
		}  



		if (x[k] < n && k < n) 
			k = k + 1;                     //44444安排下一个作业
        else {
			if (x[k] < n && k == n)  //77777777777777777777 55555得到一个作业安排
				{//
				if (bestTime > sum2[k]){
					bestTime = sum2[k];
					cout<<"最短的作业安排是:";
					for (int j = 1; j <= n; j++)
						cout<<x[j] + 1<<"  ";        数组下标从0开始,打印作业编号从1开始
				}
			}
			else//x[k] >= n  //777777777777777777777777777
			x[k] = -1; k = k - 1;             //666666重置x[k],回溯
		}
	}
	return bestTime;
}

2.结果示例
在这里插入图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值