MT3020 任务分配

简介: MT3020 任务分配

8bd7c2a95915482aa1829263f557ea05.jpg

670e71cb18894cafbdf277b6ec0f5b59.jpg


思路:利用二分找到某个时间是满足“k个人可以完成” ,并且时间最小。

因为尽量让后面的人做任务,所以从后往前排任务(倒着分配)。从后往前遍历任务,如果此人加上这个任务超出之前求得的时间,就移到上一个人。

 
#include <bits/stdc++.h>
using namespace std;
#define int long long
const int N = 1e4 + 10;
int t, k;
int ti[N];
 
bool check(int u)
{              // u秒可不可以由k个人完成
    int s = 1; // 记录当前的人
    int a[N];  // 记录每人任务时间
    memset(a, 0, sizeof(a));
    for (int i = 1; i <= t; i++) // 遍历t个任务
    {
        if (a[s] + ti[i] > u) // 如果当前时间加上当前任务的时间大于u
        {
            s++; // 选下一个人
            a[s] += ti[i];
        }
        else
            a[s] += ti[i];
    }
    if (s > k)
    { // 人数>k
        return false;
    }
    return true;
}
int c[N][2]; //[每人][起点+终点]
void print(int u)
{ // u为时间
    // 倒着分配
    int i = k, temp = 0;
    for (int j = t; j > 0; j--)
    {
        if (c[i][1] == 0)
        { // 结束
            c[i][1] = j;
        }
        if (temp + ti[j] > u) // 时间超出,则换人(从后往前i--)
        {
            c[i][0] = j + 1;
            i--;
            temp = ti[j];
            c[i][1] = j; // 结束
        }
        else
        { // 时间未超出
            temp += ti[j];
        }
    }
    c[i][0] = 1;
    for (int i = 1; i <= k; i++)
    {
        if (c[i][0] == 0)
            cout << 0 << " " << 0 << endl;
        else
            cout << c[i][0] << " " << c[i][1] << endl;
    }
}
signed main()
{
    int l = -1, r = 0, ans = 0;
    cin >> t >> k;
    for (int i = 1; i <= t; i++)
    {
        cin >> ti[i];
        l = max(l, ti[i]);//记录最大时间
        r += ti[i];//记录总时间
    }
 
    // 二分任务的时间
    while (l <= r)
    {
        int mid = (l + r) / 2;
        if (check(mid))
        {
            r = mid - 1;
            ans = mid;
        }
        else
        {
            l = mid + 1;
        }
    }
    print(ans);
    return 0;
}


相关文章
|
8月前
LabVIEW为什么NI 6602的两个计数器中只能有1个工作
LabVIEW为什么NI 6602的两个计数器中只能有1个工作
53 4
|
8月前
|
传感器
GE通用电气 IC698PSA350 PACSystem RX7i 高容量电源模块
`IC698PSA350` 是一款适用于 `PACSystem RX7i` 平台的高容量电源模块,由艾默生自动化(前 GE IP)制造。该模块支持 `85-264 VAC` 或 `100-150 VDC` 输入,最大功率 `500 W`,提供 `5 VDC`, `12 VDC`, `-12 VDC` 三路输出,总计 `350 W`。模块占用 `RX7i` 机架的 `0` 号插槽,配备状态 LED 指示灯及过温、过压保护。有两种版本(A 系列和 B 系列),内置不同类型的保险丝。模块工作频率 `47-63 Hz`,温度范围 `0-60°C`,并具有气流检测功能。安装时需确保无电连接且正确接地。
|
算法 Java 调度
【车间调度】基于GA/PSO/SA/ACO/TS优化算法的车间调度比较(Matlab代码实现)
【车间调度】基于GA/PSO/SA/ACO/TS优化算法的车间调度比较(Matlab代码实现)
126 0
|
传感器 消息中间件 网络协议
【玩转RT-Thread】CPK-RA6M4智慧门禁系统教学(上)
【玩转RT-Thread】CPK-RA6M4智慧门禁系统教学
183 0
|
编译器
MOTOROLA MVME172PA-652SE 保持流水线满负荷并避免停顿
MOTOROLA MVME172PA-652SE 保持流水线满负荷并避免停顿
86 0
MOTOROLA MVME172PA-652SE 保持流水线满负荷并避免停顿
|
并行计算 算法 编译器
ABB FAN D2D160-CE02-11 多核处理也影响了现代计算软件开发的能力
ABB FAN D2D160-CE02-11 多核处理也影响了现代计算软件开发的能力
ABB FAN D2D160-CE02-11 多核处理也影响了现代计算软件开发的能力
|
传感器 监控
ABB PM511V16 3BSE011181R1 现场控制处理器模块
ABB PM511V16 3BSE011181R1 现场控制处理器模块
104 0
ABB PM511V16 3BSE011181R1 现场控制处理器模块
【NI Multisim 14.0编辑环境——项目管理器】
一、项目管理器 在原理图设计中经常用到的工作面板有“设计工具箱”面板、“SPICE网表查看器”面板及“LabVIEW 协同仿真终端”面板。 1.“设计工具箱”面板 基本位于工作界面左侧,主要用于层次电路的显示。启动软件,默认创建的“设计1”以分层的形式显示出来。 那么如何打开“设计工具箱”面板呢?如图所示: 首先点击菜单栏的【视图】,再去勾选【设计工具箱】的选项。如图所示: 勾选完之后,我们可以在工作界面上找到“设计工具箱”面板了。如图所示: 该面板显示3个选项卡,如图所示。 “层次”选项卡用于对不同电路的分层显示,创建的“设计2”以同样的分层方式显示。 “可见度”选项卡用于显示同一电路的不同
380 0
【NI Multisim 14.0编辑环境——项目管理器】
|
异构计算
FPGA-LCD1602显示-第一次尝试使用task写可综合程序
FPGA-LCD1602显示-第一次尝试使用task写可综合程序
330 0
FPGA-LCD1602显示-第一次尝试使用task写可综合程序
把几个任务分配到几个设备上的代码
把几个任务分配到几个设备上的代码
48 0