多机调度问题

cpp 复制代码
#include<iostream>
#include<string>
using namespace std;
struct work
{
    int time;
    int number;
};
int setwork0(int m,int n,int a[],struct work w[])
{
    int maxtime=0;
    for(int i=1; i<=m; i++)
    {
        cout<<i<<"号设备处理作业"<<w[i].number<<endl;
        a[i]=w[i].time;
        if(maxtime<a[i])
            maxtime=a[i];
    }
    return maxtime;
}
int setwork1(int m,int n,int a[],struct work w[])
{
    int maxtime=0;
    for(int i=1; i<=n; i++)
    {
        a[i]=w[i].time;
        cout<<i<<"号设备处理作业"<<w[i].number<<endl;
    }
    int t=n+1;
    while(t<=m)
    {
        int min0=n;
        for(int i=1; i<=n; i++)
        {
            if(a[min0]>a[i])
            {
                min0=i;
            }
        }
        a[min0]+=w[t].time;
        cout<<min0<<"号设备处理作业"<<w[t].number<<endl;
        t++;
    }

    for(int i=1; i<=n; i++)
    {
        if(maxtime<a[i])
            maxtime=a[i];
    }
    return maxtime;
}
int main()
{
    int n;
    cout<<"共有n个设备:";
    cin>>n;
    int m;
    cout<<"共有m个作业:";
    cin>>m;
    struct work w[m+1];
    cout<<"输入处理时间:";
    for(int i=1; i<=m; i++)
    {
        w[i].number=i;
        cin>>w[i].time;
    }

    int a[n+12];
    int maxtime=0;
    if(m<=n)
        maxtime=setwork0(m,n,a,w);
    else
    {
        for(int i=1; i<=m; i++)
        {
            for(int j=i; j<=m; j++)
            {
                if(w[i].time<w[j].time)
                {
                    struct work t=w[i];
                    w[i]=w[j];
                    w[j]=t;
                }

            }
        }
        for(int i=1; i<=m; i++)
        {
            cout<<w[i].number<<"号作业的处理时间:"<<w[i].time<<endl;
        }
        maxtime=setwork1(m,n,a,w);
    }

    cout<<"最长处理时间:"<<maxtime;
    return 0;
}
相关推荐
go546315846510 分钟前
修改Spatial-MLLM项目,使其专注于无人机航拍视频的空间理解
人工智能·算法·机器学习·架构·音视频·无人机
油泼辣子多加27 分钟前
【Torch】nn.BatchNorm1d算法详解
算法
nlog3n27 分钟前
基于 govaluate 的监控系统中,如何设计灵活可扩展的自定义表达式函数体系
算法·go
IT古董39 分钟前
【第三章:神经网络原理详解与Pytorch入门】01.神经网络算法理论详解与实践-(2)神经网络整体结构
pytorch·神经网络·算法
ThetaarSofVenice1 小时前
垃圾收集相关算法Test
java·jvm·算法
小陈phd1 小时前
langchain从入门到精通(二十八)——RAG优化策略(六)集成多种检索器算法实现混合检索及问题转换总结
算法
是小王同学啊~1 小时前
(LangChain)RAG系统链路向量检索器之Retrievers(五)
python·算法·langchain
薰衣草23331 小时前
一天两道力扣(1)
算法·leetcode·职场和发展
一粒沙白猫1 小时前
Java综合练习04
java·开发语言·算法
爱coding的橙子2 小时前
每日算法刷题Day41 6.28:leetcode前缀和2道题,用时1h20min(要加快)
算法·leetcode·职场和发展