P1190 接水问题

题目描述

学校里有一个水房,水房里一共装有 \(m\) 个龙头可供同学们打开水,每个龙头每秒钟的供水量相等,均为1。

现在有 \(n\) 名同学准备接水,他们的初始接水顺序已经确定。将这些同学按接水顺序从 1 到 \(n\) 编号,\(i\) 号同学的接水量为 \(w_i\) ​。接水开始时,\(1\) 到 \(m\) 号同学各占一个水龙头,并同时打开水龙头接水。当其中某名同学 \(j\) 完成其接水量要求 \(w_j\) 后,下一名排队等候接水的同学 \(k\) 马上接替 \(j\) 同学的位置开始接水。这个换人的过程是瞬间完成的,且没有任何水的浪费。即 \(j\) 同学第 \(x\) 秒结束时完成接水,则 \(k\) 同学第 \(x+1\) 秒立刻开始接水。若当前接水人数 \(n'\) 不足 \(m\),则只有 \(n'\)个龙头供水,其它 \(m−n’\)个龙头关闭。

现在给出 \(n\) 名同学的接水量,按照上述接水规则,问所有同学都接完水需要多少秒。

输入格式

第 1 行 2 个整数 \(n\) 和 \(m\),用一个空格隔开,分别表示接水人数和龙头个数。

第 2 行 \(n\) 个整数 \(w_1,w_2,…,w_n\),每两个整数之间用一个空格隔开,\(w_i\)​表示 \(i\) 号同学的接水量。

输出格式

1 个整数,表示接水所需的总时间。

输入输出样例

输入 #1

5 3

4 4 1 2 1

输出 #1

4

输入 #2

8 4

23 71 87 32 70 93 80 76

输出 #2

163

说明/提示

【输入输出样例 1 说明】

第 1 秒,3人接水。第 1秒结束时,1,2,3 号同学每人的已接水量为 1,3 号同学接完水,4 号同学接替 3 号同学开始接水。

第 2 秒,3 人接水。第 2 秒结束时,1,2 号同学每人的已接水量为 2,4 号同学的已接水量为 1。

第 3 秒,3 人接水。第 3 秒结束时,1,2 号同学每人的已接水量为 3,4 号同学的已接水量为2。4 号同学接完水,5 号同学接替 4 号同学开始接水。

第 4 秒,3 人接水。第 4 秒结束时,1,2 号同学每人的已接水量为 4,5 号同学的已接水量为 1。1,2,5 号同学接完水,即所有人完成接水的总接水时间为 4 秒。

【数据范围】

\(1≤n≤10000,1≤m≤100\) 且 \(m≤n\);

\(1≤w_i≤100\) 。

【思路】

贪心 + 模拟

又是没读好题目惹的祸,

导致明明是一道很好做的题目花了好久的时间

明明没有那么复杂,只需要输入的顺序排队就好

我却因为没读好题目

想贪心将没接水的人里面需要接水最多的人

和正在接水的某一个水龙头上目前需要接水的人的接水总量最少的那一个组合在一起

还想当然的弄了两个优先队列,

没想到需要按照输入的顺序

不能插队啊!插队是不文明行为!

贪心思想:

目前这个需要接水的人应该去水龙头里面目前需要接水的人的接水总量最少的那一个

这样会使消耗的时间最少

因为除了选择那一个接水总量最少的,

你选择别的都会有可能使需要消耗的时间

也就是接水总量最大值变得更大

因为 如果 a > b,现在你有一个c,

你放到a里面之后加起来的值a + c 一定小于 b + c

这是很显然的

只需要用一个优先队列和一个普通队列来储存他们排队的顺序来处理

现将前m个放入优先队列(小根堆)中,剩余的放入普通队列

每一次都把普通队列的队首和优先队列的队首(即最小值)拿出来相加起来

然后再放进优先队列里面

这样重复下去直到普通队列变为空

最后输出优先队列里面最后一个元素

也就是最大值就可以了

【完整代码】

#include<iostream>
#include<cstdio>
#include<queue>
using namespace std;
queue<int>q;
priority_queue<int,vector<int>,greater<int> > s;
int main()
{
int n,m;
int qwq;
scanf("%d%d",&n,&m);
for(int i = 1;i <= m;++ i)
scanf("%d",&qwq),s.push(qwq);
for(int i = m + 1;i <= n;++ i)
{
scanf("%d",&qwq),q.push(qwq);
}
while(!q.empty())
{
int awa = q.front();q.pop();
int owo = s.top();s.pop();
s.push(awa + owo);
}
int ans;
while(!s.empty())
{
ans = s.top();
s.pop();
}
cout << ans << endl;
return 0;
}

洛谷 P1190 接水问题 题解的更多相关文章

  1. 洛谷P1190 接水问题

    题目名称:接水问题 题目来源 [洛谷P1190] (https://www.luogu.org/problemnew/show/P1190)​ 题目描述 学校里有一个水房,水房里一共有\(m\)个龙头 ...

  2. 洛谷——P1190 接水问题

    P1190 接水问题 题目描述 学校里有一个水房,水房里一共装有 m 个龙头可供同学们打开水,每个龙头每秒钟的供水量相等,均为 1. 现在有 n 名同学准备接水,他们的初始接水顺序已经确定.将这些同学 ...

  3. 洛谷—— P1190 接水问题

    https://www.luogu.org/problem/show?pid=1190#sub 题目描述 学校里有一个水房,水房里一共装有 m 个龙头可供同学们打开水,每个龙头每秒钟的 供水量相等,均 ...

  4. 洛谷P1783 海滩防御 分析+题解代码

    洛谷P1783 海滩防御 分析+题解代码 题目描述: WLP同学最近迷上了一款网络联机对战游戏(终于知道为毛JOHNKRAM每天刷洛谷效率那么低了),但是他却为了这个游戏很苦恼,因为他在海边的造船厂和 ...

  5. 洛谷P4047 [JSOI2010]部落划分题解

    洛谷P4047 [JSOI2010]部落划分题解 题目描述 聪聪研究发现,荒岛野人总是过着群居的生活,但是,并不是整个荒岛上的所有野人都属于同一个部落,野人们总是拉帮结派形成属于自己的部落,不同的部落 ...

  6. 洛谷P1155 双栈排序题解(图论模型转换+二分图染色+栈)

    洛谷P1155 双栈排序题解(图论模型转换+二分图染色+栈) 标签:题解 阅读体验:https://zybuluo.com/Junlier/note/1311990 原题地址:洛谷P1155 双栈排序 ...

  7. BZOJ2527 & 洛谷3527:[Poi2011]Meteors——题解

    +++++++++++++++++++++++++++++++++++++++++++ +本文作者:luyouqi233. + +欢迎访问我的博客:http://www.cnblogs.com/luy ...

  8. 洛谷10月月赛II题解

    [咻咻咻] (https://www.luogu.org/contestnew/show/11616) 令人窒息的洛谷月赛,即将参加NOIp的我竟然只会一道题(也可以说一道也不会),最终145的我只能 ...

  9. [洛谷P1823]音乐会的等待 题解(单调栈)

    [洛谷P1823]音乐会的等待 Description N个人正在排队进入一个音乐会.人们等得很无聊,于是他们开始转来转去,想在队伍里寻找自己的熟人.队列中任意两个人A和B,如果他们是相邻或他们之间没 ...

随机推荐

  1. pytorch 0.4.0迁移指南

    总说 由于pytorch 0.4版本更新实在太大了, 以前版本的代码必须有一定程度的更新. 主要的更新在于 Variable和Tensor的合并., 当然还有Windows的支持, 其他一些就是支持s ...

  2. 流程activiti的组和用户的使用

    一.数据表增加用户和分组 1.建立用户 2.建立组 3.建立用户和组的关联关系 二.新建测试流程 1.流程整体 2.设置“部门经理”任务的属性,填写组的ID 3.设置“总经理”任务的属性,填写组的ID ...

  3. java之struts2的数据处理

    这里的数据处理,指的是页面上的数据与Action中的数据的处理. struts2中有3种方式来接收请求提交的数据.分别是:属性驱动方式.对象驱动方式.模型驱动方式 1. 属性驱动方式 要求页面中的表单 ...

  4. git push proxy 取消不掉 can not prox....

    使用这个折腾了半天 git config --global --unset http.proxy git config --global --unset https.proxy 没用,原来实现项目目录 ...

  5. 深入剖析Linux IO原理和几种零拷贝机制的实现

    深入剖析Linux IO原理和几种零拷贝机制的实现 来源 https://zhuanlan.zhihu.com/p/83398714 零壹技术栈      公众号[零壹技术栈] 前言 零拷贝(Zero ...

  6. PHP利用preg_split函数格式化日期

    // 2018/2/13 00:26:00.000 function format_date($date, $format='Y-m-d H:i:s') { if(empty($date)) retu ...

  7. 【一起学源码-微服务】Netflix Eureka 源码一:Netflix Eureka 源码初探,我们为什么要读源码?

    前言 最近发现 网上好多自己的博客,很多朋友转载了文章却不加下 原载地址,本文欢迎转载一起学习,请在目录出加上原出处,感谢.转载来自:博客(一枝花算不算浪漫) 看了前面几篇文章的小伙伴知道,前几天在学 ...

  8. Java 之 常用函数式接口

    JDK提供了大量常用的函数式接口以丰富Lambda的典型使用场景,它们主要在 java.util.function 包中被提供.下面是最简单的几个接口及使用示例. 一.Supplier 接口 java ...

  9. Python学习日记(十六) time模块和random模块

    time模块 python表示时间的三种方式:时间戳.元祖(struct_time).格式化时间字符串 三种格式之间的转换: 1.时间戳 就是从1970年1月1日0点0分0秒开始按秒计算的偏移量,时间 ...

  10. xadmin 配置内置User模型

    xadmin 配置内置USER模型 默认展示 在你的User模型对应的app下创建adminx 文件 import xadmin from django.contrib.auth import get ...