MT3020 任务分配

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

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

cpp 复制代码
#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;
}
相关推荐
承渊政道1 分钟前
【动态规划算法】(简单多状态dp问题入门与经典题型解析)
数据结构·c++·学习·算法·leetcode·macos·动态规划
南境十里·墨染春水2 分钟前
C++笔记——STL map
开发语言·c++·笔记
fie88899 分钟前
免疫优化算法在物流配送中心选址中的应用
算法·数学建模
南境十里·墨染春水15 分钟前
C++笔记·-- STL unordered_map
开发语言·c++·笔记
珹洺18 分钟前
C++远程调用组件库JsonRpc(一)项目背景、核心概念与环境搭建
开发语言·c++·rpc
王老师青少年编程20 分钟前
csp信奥赛C++高频考点专项训练之贪心算法 --【部分背包问题】:部分背包问题
c++·算法·贪心·csp·信奥赛·部分背包问题
handler0121 分钟前
【Linux 笔记】GDB 调试速查手册
linux·运维·c语言·c++·笔记
九思十安23 分钟前
HNU2026-算法设计与分析-笔记 3 摊还分析
笔记·算法
无忧.芙桃24 分钟前
现代C++讲解之enum class,static_assert,tuple的使用
开发语言·c++
6Hzlia26 分钟前
【Hot 100 刷题计划】 LeetCode 142. 环形链表 II | C++ 哈希表直觉解法
c++·leetcode·链表