对于第i个打水的人来说,他所花的时间为上一个在该水龙头打水的人所需的时间+自己打水所需的时间
#include <iostream>
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const long long maxn=1e5+10;
int a[maxn],b[maxn],c[maxn],prime[maxn];
int main()
{
int i,j,k,mid,x2,y2,d,u,g,p,sum=0;
cin>>n>>m;
for (i=1;i<=n;i++)
{
cin>>a[i];
}
sort(a+1,a+n+1);//为了让打水时间最少,需排序,让等待时间最少
for (i=1;i<=n;i++){
if(i>m) a[i]+=a[i-m];//超出水龙头个数的人,他们的打水时间是上一个在该水龙头打水的人的时间+自己所需的时间
sum+=a[i];
}
cout<<sum;
return 0;
}
0.0分
2 人评分
C语言程序设计教程(第三版)课后习题3.7 (C语言代码)浏览:1066 |
printf基础练习2 (C语言代码)浏览:567 |
C语言程序设计教程(第三版)课后习题5.6 (C语言代码)浏览:850 |
简单的a+b (C语言代码)浏览:573 |
兰顿蚂蚁 (C++代码)浏览:1044 |
C语言程序设计教程(第三版)课后习题8.1 (C语言代码)浏览:517 |
C语言训练-尼科彻斯定理 (C语言代码)浏览:463 |
简单的for循环浏览:1408 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:1142 |
WU-陶陶摘苹果2 (C++代码)浏览:968 |