题目描述
有 nn 个人在一个水龙头前排队接水,假如每个人接水的时间为 T_iTi,请编程找出这 nn 个人排队的一种顺序,使得 nn 个人的平均等待时间最小。
输入格式
第一行为一个整数 n。
第二行 n 个整数,第 i个整数 Ti 表示第 i个人的等待时间 Ti。
输出格式
输出文件有两行,第一行为一种平均时间最短的排队顺序;第二行为这种排列方案下的平均等待时间(输出结果精确到小数点后两位)。
输入输出样例
输入 #1复制
10
56 12 1 99 1000 234 33 55 99 812
输出 #1复制
3 2 7 8 1 4 9 6 10 5
291.90
说明/提示
n \leq 1000,t_i \leq 10^6n≤1000,ti≤106,不保证 t_iti 不重复。
当 t_iti 重复时,按照输入顺序即可(sort 是可以的)
解析:利用贪心算法,知道时间短的要先完成,才能最省时间。那么这个题目就只剩排序了,因为要打印出初始位置,所以利用结构体来储存。接着利用结构体sort排序。
#include<bits/stdc++.h>
using namespace std;
struct node{
int data;
int pos;
};
bool tmp(struct node a,struct node b)
{
if(a.data<b.data){
return true;
}
else{
return false;
}
}
int main()
{
int n;
cin>>n;
struct node a[n];
int i;
for(i=0;i<n;i++){
cin>>a[i].data;
a[i].pos=i+1;
}
sort(a,a+n,tmp);
for(i=0;i<n;i++){
cout<<a[i].pos<<" ";
}
cout<<endl;
double sum=0,k=0;
for(i=1;i<n;i++){
k+=a[i-1].data;
sum+=k;
}
printf("%.2lf",sum/n);
return 0;
}