日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

codevs1127 接水问题

發布時間:2024/4/17 编程问答 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 codevs1127 接水问题 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
題目描述?Description

學校里有一個水房,水房里一共裝有m 個龍頭可供同學們打開水,每個龍頭每秒鐘的供水量相等,均為1。


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


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

輸入描述?Input Description

第1 行2 個整數n 和m,用一個空格隔開,分別表示接水人數和龍頭個數。
第2 行n 個整數w1、w2、……、wn,每兩個整數之間用一個空格隔開,wi 表示i 號同
學的接水量。

輸出描述?Output Description

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

樣例輸入?Sample Input

5 3
4 4 1 2 1

樣例輸出?Sample Output

4

數據范圍及提示?Data Size & Hint

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

思路: 每來一個人,就把這個人拼接到剩余時間最少的隊伍上,然后取剩余時間最多的隊伍為答案 代碼: #include<iostream> #include<cstdio> #include<algorithm>const int maxm = 101; using namespace std; int main(){int n = 0,m = 0,rap[maxm],i = 0,r = 0,j = 0,k = 0,l = 0,time = 0,base = 0;scanf("%d",&n);scanf("%d",&m);for(i = 0;i < m;i++) scanf("%d",&rap[i]);sort(rap,rap + m);while((k < n - m) && (scanf("%d",&r) == 1)){rap[0] += r;sort(rap,rap + m);}cout<<rap[m - 1]<<endl;return 0; }

?

轉載于:https://www.cnblogs.com/hyfer/p/5812519.html

總結

以上是生活随笔為你收集整理的codevs1127 接水问题的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。