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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

NOIP2010排队接水

發(fā)布時(shí)間:2024/10/12 编程问答 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 NOIP2010排队接水 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

題目描述

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

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

現(xiàn)在給出 n 名同學(xué)的接水量,按照上述接水規(guī)則,問所有同學(xué)都接完水需要多少秒。

輸入輸出格式

輸入格式:

?

輸入文件名為 water.in。

第 1 行 2 個(gè)整數(shù) n 和 m,用一個(gè)空格隔開,分別表示接水人數(shù)和龍頭個(gè)數(shù)。

第 2 行 n 個(gè)整數(shù) w1、w2、……、wn,每兩個(gè)整數(shù)之間用一個(gè)空格隔開,wi表示 i 號(hào)同

學(xué)的接水量。

?

輸出格式:

?

輸出文件名為 water.out。

輸出只有一行,1 個(gè)整數(shù),表示接水所需的總時(shí)間。

?

輸入輸出樣例

輸入樣例#1:?復(fù)制 【輸入樣例1】 5 3 4 4 1 2 1 【輸入樣例2】 8 4 23 71 87 32 70 93 80 76 輸出樣例#1:?復(fù)制 【輸出樣例1】 4 【輸出樣例2】 163

說明

【輸入輸出樣例 1 說明】

第 1 秒,3 人接水。第 1 秒結(jié)束時(shí),1、2、3 號(hào)同學(xué)每人的已接水量為 1,3 號(hào)同學(xué)接完

水,4 號(hào)同學(xué)接替 3 號(hào)同學(xué)開始接水。

第 2 秒,3 人接水。第 2 秒結(jié)束時(shí),1、2 號(hào)同學(xué)每人的已接水量為 2,4 號(hào)同學(xué)的已接

水量為 1。

第 3 秒,3 人接水。第 3 秒結(jié)束時(shí),1、2 號(hào)同學(xué)每人的已接水量為 3,4 號(hào)同學(xué)的已接

水量為 2。4 號(hào)同學(xué)接完水,5 號(hào)同學(xué)接替 4 號(hào)同學(xué)開始接水。

第 4 秒,3 人接水。第 4 秒結(jié)束時(shí),1、2 號(hào)同學(xué)每人的已接水量為 4,5 號(hào)同學(xué)的已接

水量為 1。1、2、5 號(hào)同學(xué)接完水,即所有人完成接水。

總接水時(shí)間為 4 秒。

【數(shù)據(jù)范圍】

1≤n≤10000,1≤m≤100 且 m≤n;

1≤wi≤100。

一道十分垃圾的純模擬;

#include<iostream>
#include<cstdio>
#include<cstdlib>
using namespace std;
int n,m,a[10110],js[11010],maxa,g[11010],count;
long long i;
int main(){
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++){
scanf("%d",&a[i]);
if(a[i]>maxa)maxa=a[i];
}
if(n<m){cout<<maxa;return 0;}
for(int i=1;i<=m;i++)g[i]=i;
maxa=g[m];
while(count<n){
for(int j=1;j<=m;j++){
js[g[j]]++;
if(js[g[j]]==a[g[j]]){count++;g[j]=maxa+1;maxa=g[j];}
}
i++;
}
cout<<i;
}

轉(zhuǎn)載于:https://www.cnblogs.com/linzeli/p/7749641.html

總結(jié)

以上是生活随笔為你收集整理的NOIP2010排队接水的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。