多机调度问题

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;
}
相关推荐
平安的平安22 分钟前
面向大模型算子开发的高效编程范式PyPTO深度解析
c++·mfc
June`23 分钟前
muduo项目排查错误+测试
linux·c++·github·muduo网络库
C++ 老炮儿的技术栈28 分钟前
VS2015 + Qt 实现图形化Hello World(详细步骤)
c语言·开发语言·c++·windows·qt
YuTaoShao28 分钟前
【LeetCode 每日一题】3634. 使数组平衡的最少移除数目——(解法一)排序+滑动窗口
算法·leetcode·排序算法
Once_day36 分钟前
C++之《Effective C++》读书总结(4)
c语言·c++·effective c++
波波00736 分钟前
每日一题:.NET 的 GC是如何分代工作的?
算法·.net·gc
柯一梦39 分钟前
STL2---深入探索vector的实现
c++
风暴之零1 小时前
变点检测算法PELT
算法
深鱼~1 小时前
视觉算法性能翻倍:ops-cv经典算子的昇腾适配指南
算法·cann
李斯啦果1 小时前
【PTA】L1-019 谁先倒
数据结构·算法