算法:动态规划解决流水作业问题

时间:2022-04-12 08:00:04 阅读: 最新文章 文档下载
说明:文章内容仅供预览,部分内容可能不全。下载后的文档,内容与下面显示的完全一致。下载之前请确认下面内容是否您想要的,是否完整无缺。
算法:动态规划解决流水作业问题

//3d9 动态规划 流水作业调度问题 #include "stdafx.h" #include using namespace std; const int N = 5; class Jobtype { public: int operator <=(Jobtype a) const { return(key<=a.key); } int key,index; bool job; };

int FlowShop(int n,int a[],int b[],int c[]);

void BubbleSort(Jobtype *d,int n);//本例采用冒泡排序 int main() { int a[] = {2,4,3,6,1}; int b[] = {5,2,3,1,7}; int c[N]; int minTime = FlowShop(N,a,b,c);

cout<<"作业在机器1上的运行时间为:"<for(int i=0; i{ cout<}

cout<

cout<<"作业在机器2上的运行时间为:"<for(int i=0; i{ cout<}

cout<

cout<<"完成作业的最短时间为:"<cout<<"编号从0开始,作业调度的顺序为:"<for(int i=0; i{ cout<}

cout<


return 0; }

int FlowShop(int n,int a[],int b[],int c[]) { Jobtype *d = new Jobtype[n]; for(int i=0; i { d[i].key = a[i]>b[i]?b[i]:a[i];//Johnson法则分别取对应的b[i]a[i]值作为关键字 d[i].job = a[i]<=b[i];//给符合条件a[i]的放入到N1子集标记为true d[i].index = i; } BubbleSort(d,n);//对数组d按关键字升序进行排序 int j = 0,k = n-1; for(int i=0; i { if(d[i].job) { c[j++] = d[i].index;//将排过序的数组d,取其中作业序号属于N1的从前面进入 } else { c[k--] = d[i].index;//属于N2的从后面进入,从而实现N1的非减序排序,N2非增序排序 } } j = a[c[0]]; k = j+b[c[0]]; for(int i=1; i { j += a[c[i]];//M1在执行c[i]作业的同时,M2在执行c[i-1]号作业,最短执行时间取决于M1M2谁后执行完 k = j计算最优加工时间 } delete d; return k; }

//冒泡排序

void BubbleSort(Jobtype *d,int n) { int i,j,flag; Jobtype temp; for(i=0;i flag = 0; for(j=n-1;j>i;j--){


}

}

}

//如果前一个数大于后一个数,则交换 if(d[j]<=d[j-1]){ temp = d[j]; d[j] = d[j-1]; d[j-1] = temp; flag = 1; }

//如果本次排序没有进行一次交换,则break,减少了执行之间。 if(flag == 0){ break; }


本文来源:https://www.wddqw.com/doc/b8df761eed06eff9aef8941ea76e58fafab04513.html