天天看點

NOIP2010普及組T3 接水問題 ——S.B.S.

題目描述

學校裡有一個水房,水房裡一共裝有 m 個龍頭可供同學們打開水,每個龍頭每秒鐘的

供水量相等,均為 1。

現在有 n 名同學準備接水,他們的初始接水順序已經确定。将這些同學按接水順序從 1到 n 編号,i 号同學的接水量為 wi。接水開始時,1 到 m 号同學各占一個水龍頭,并同時打開水龍頭接水。當其中某名同學 j 完成其接水量要求 wj後,下一名排隊等候接水的同學 k馬上接替 j 同學的位置開始接水。這個換人的過程是瞬間完成的,且沒有任何水的浪費。即j 同學第 x 秒結束時完成接水,則 k 同學第 x+1 秒立刻開始接水。若目前接水人數 n’不足 m,則隻有 n’個龍頭供水,其它 m−n’個龍頭關閉。

現在給出 n 名同學的接水量,按照上述接水規則,問所有同學都接完水需要多少秒。

輸入輸出格式

輸入格式:

輸入檔案名為 water.in。

第 1 行 2 個整數 n 和 m,用一個空格隔開,分别表示接水人數和龍頭個數。

第 2 行 n 個整數 w1、w2、……、wn,每兩個整數之間用一個空格隔開,wi表示 i 号同

學的接水量。

輸出格式:

輸出檔案名為 water.out。

輸出隻有一行,1 個整數,表示接水所需的總時間。

輸入輸出樣例

輸入樣例#1:

【輸入樣例1】
5 3 
4 4 1 2 1 
【輸入樣例2】
8 4 
23 71 87 32 70 93 80 76       

輸出樣例#1:

【輸出樣例1】
4
【輸出樣例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≤wi≤100。

————————————————————我是分割線——————————————————————————————

水題,純模,優先隊列秒殺。

1 #include<iostream>
 2 #include<cstdio>
 3 #include<cstring>
 4 #include<cmath>
 5 #include<algorithm>
 6 #include<queue>
 7 #include<cstdlib>
 8 using namespace std;
 9 priority_queue< int,vector<int>,greater<int> > s;//注意greater<int>與>s之間必須有空格,否則編譯器會認為是>>而報錯 
10 int read(){
11     int x=0,f=1;char ch=getchar();
12     while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
13     while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
14     return x*f;
15 }
16 int main()
17 {
18     int n,m,d;
19     std::ios::sync_with_stdio(false);
20     n=read();m=read();
21     for(int i=1;i<=m;i++) s.push(0);
22     for(int i=1;i<=n;i++)
23     {
24         d=read();
25         s.push(s.top()+d);
26         s.pop();
27     }
28     while((s.size()-1)!=0) s.pop();
29     cout<<s.top();
30     return 0;
31 }      

接水問題

轉載于:https://www.cnblogs.com/AwesomeOrion/p/5418875.html