多机调度问题

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;
}
相关推荐
风筝在晴天搁浅31 分钟前
n个六面的骰子,扔一次之后和为k的概率是多少?
算法
KuaCpp33 分钟前
C++面向对象(速过复习版)
开发语言·c++
MATLAB代码顾问2 小时前
Python实现蜂群算法优化TSP问题
开发语言·python·算法
代码飞天2 小时前
机器学习算法和函数整理——助力快速查阅
人工智能·算法·机器学习
jiushiapwojdap2 小时前
LU分解法求解线性方程组Matlab实现
数据结构·其他·算法·matlab
笨笨饿2 小时前
69_如何给自己手搓一个串口
linux·c语言·网络·单片机·嵌入式硬件·算法·个人开发
纽扣6673 小时前
【算法进阶之路】链表进阶:删除、合并、回文与排序全解析
数据结构·算法·链表
消失的旧时光-19433 小时前
统一并发模型:线程、Reactor、协程本质是一件事(从线程到协程 · 第6篇·终章)
java·python·算法
智者知已应修善业3 小时前
【51单片机不用数组动态数码管显示字符和LED流水灯】2023-10-3
c++·经验分享·笔记·算法·51单片机
AI进化营-智能译站4 小时前
ROS2 C++开发系列16-智能指针管理传感器句柄|告别ROS2节点内存泄漏与野指针
java·c++·算法·ai