东华OJ-进阶题-19-排队打水问题(C++)

  • 问题描述
    有n个人排队到r个水龙头去打水,他们装满水桶的时间t1、t2............tn为整数且各不相等,应如何安排他们的打水顺序才能使他们总共花费的时间最少?
  • 输入说明
      第一行n,r (n<=500,r<=75)
      第二行为n个人打水所用的时间Ti (Ti<=100);
  • 输出说明
    最少的花费时间
  • 输入范例
cpp 复制代码
3 2
1 2 3
  • 输出范例
cpp 复制代码
7

感想:用到priority_queue SJF最短作业优先策略就方便很多,pq 堆排序适合贪心。
代码如下:

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

int main() {
    int n,r;
    cin>>n>>r;
    vector<int> cost(n);
    for(int i = 0; i<n; ++i) {
        cin>>cost[i];
    }
    sort(cost.begin(),cost.end());
    // 小顶堆,存储每个水龙头的当前累计时间
    priority_queue<int, vector<int>, greater<int>> pq;
    for (int i = 0; i < r; ++i) {
        pq.push(0); // 初始所有水龙头空闲
    }

    int total = 0; // 总花费时间
    for (int i = 0; i < n; ++i) {
        int curr = pq.top();
        pq.pop();
        total+=curr+cost[i];
        pq.push(curr+cost[i]);//更新水龙头目前时间
    }

    cout << total << endl;
    return 0;
}
相关推荐
全糖可乐气泡水几秒前
Codex适配国产信创环境安装部署与技术适配全解析
开发语言·git·python·算法·百度
雨落在了我的手上4 分钟前
初始java(十):类和对象(⼆)
java·开发语言
LeocenaY6 分钟前
搜集的一些测开面试题
开发语言·python
h_a_o777oah13 分钟前
状态机+划分型 DP :深度解析K-划分问题下 DP 状态的转移逻辑(洛谷P2679 P2331 附C++代码)
c++·算法·动态规划·acm·状态机dp·划分型dp·滚动数组优化
05候补工程师19 分钟前
从算法理想向工程现实的跨越:SLAM 核心架构、思维误区与 Nav2 实战避坑指南
人工智能·算法·安全·架构·机器人
threelab24 分钟前
Three.js 加载 3D Tiles 瓦片数据 | 三维可视化 / AI 提示词
开发语言·前端·javascript·人工智能·3d·着色器
_洋1 小时前
Three.js加载 .obj文件 和 .gltf文件
开发语言·javascript·ecmascript
wjs20241 小时前
Font Awesome 性别图标
开发语言
SmartBrain1 小时前
AI全栈开发(SDD):慢病管理系统工程级设计
java·大数据·开发语言·人工智能·架构·aigc
lsx2024061 小时前
选择(Selectable)
开发语言