当前位置:首页 > 模拟 > 正文
NOI1.9-15接水问题(NOIP2010)
3604+

题目大意:m个同学排好队去接水,共有n个水龙头,先告诉你每个同学需要接多少水,请问全部接完需要多久?

题目描述

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

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

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

输入

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

第2 行n 个整数w1、w2、……、wn,每两个整数之间用一个空格隔开,wi 表示i 号同学的接水量。

输出

输出只有一行,1 个整数,表示接水所需的总时间。

样例输入

5 3
4 4 1 2 1

样例输出

4

提示

n<=10000, m<=100

第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 秒。

NOIP2010普及组第二题

解题思路

排好队,那就一个一个去接水。用完的水龙头先接。每个同学去接水的时候,看一下那个水龙头先没有人接水,即看一下哪一个水龙头接水量最少,最少的肯定先接完。同学去接水后,该水龙头的工作量(接水任务)要加一下。最后看一下那个水龙头接水量最大,最大值即是时间。

程序实现

About

坚决不Copy代码!

本文标签:,,,,,

NOI1.9-15接水问题(NOIP2010):等您坐沙发呢!

发表评论

您必须 [ 登录 ] 才能发表留言!