流水作业调度(动态规划)-算法设计与分析

//流水作业调度
const int maxn=5;
int a[]={2,4,3,6,1};
int b[]={5,2,3,1,7};
int c[maxn];
struct node
{
    int key,id;
    bool job;
};
int cmp(const node &a,const node &b)
{
    return a.key<=b.key;
}
int flow_shop()
{
    int j=0,k=maxn-1,n=maxn;
    node *d=new node[n];
    for(int i=0;i<n;i++)
    {
        d[i].key=min(a[i],b[i]);
        if(a[i]<=b[i]) d[i].job=true;
        else d[i].job=false;
        d[i].id=i;
    }
    sort(d,d+n,cmp);
    for(int i=0;i<n;i++)
        if(d[i].job)c[j++]=d[i].id;
        else c[k--]=d[i].id;
    j=a[c[0]];
    k=j+b[c[0]];
    for(int i=1;i<n;i++)
    {
        j+=a[c[i]];
        if(j<k) k+=b[c[i]];
        else k=j+b[c[i]];
    }
    return k;
}
int main()
{
    int min_time=flow_shop();
    cout<<"作业在M1上的运行时间为:";
    for(int i=0;i<maxn;i++)cout<<a[i]<<' ';
    cout<<endl;
    cout<<"作业在M2上的运行时间为:";
    for(int i=0;i<maxn;i++)cout<<b[i]<<' ';
    cout<<endl;
    cout<<"完成所有作业的最短时间为"<<min_time<<endl;
    cout<<"作业的顺序为:";
    for(int i=0;i<maxn;i++)cout<<a[i]<<' ';
    cout<<endl;
    return 0;
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值