19 排队打水问题
作者: Turbo时间限制: 1S章节: 贪心
问题描述 :
有n个人排队到r个水龙头去打水,他们装满水桶的时间t1、t2…………tn为整数且各不相等,应如何安排他们的打水顺序才能使他们总共花费的时间最少?
输入说明 :
第一行n,r (n<=500,r<=75)
第二行为n个人打水所用的时间Ti (Ti<=100);
输出说明 :
最少的花费时间
输入范例 :
3 2
1 2 3
输出范例 :
7
注意审题
#include<stdio.h>
#include<string.h>
void qsort(int a[],int n)
{
int i,j,t;
for(i=0;i<n-1;i++)
{
for(j=0;j<n-1-i;j++)
{
if(a[j]>a[j+1])
{
t=a[j];
a[j]=a[j+1];
a[j+1]=t;
}
}
}
}
int main()
{
int n,r,i,a[1010],b[1010],sum;
while(~scanf("%d%d",&n,&r))
{
sum=0;
memset(a,0,sizeof(a));
memset(b,0,sizeof(b));
for(i=0;i<n;i++) scanf("%d",&a[i]);
qsort(a,n);
for(i=0;i<r;i++) b[i]=a[i];
for(i=r;i<n;i++) b[i]=b[i-r]+a[i];
for(i=0;i<n;i++) sum+=b[i];
printf("%d\n",sum);
}
return 0;
}