有 nn 个人在一个水龙头前排队接水,假如每个人接水的时间为 T_iTi,请编程找出这 nn 个人排队的一种顺序,使得 nn 个人的平均等待时间最小。
输入格式
第一行为一个整数 nn。
第二行 nn 个整数,第 ii 个整数 T_iTi 表示第 ii 个人的等待时间 T_iTi。
输出格式
输出文件有两行,第一行为一种平均时间最短的排队顺序;第二行为这种排列方案下的平均等待时间(输出结果精确到小数点后两位)。
输入输出样例
输入 #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 是可以的)
分析,水题一个,从按接水时间小到大排序然后输出位置坐标,然说求平均节水时间,但是因为是水题,所以不用结构体,不用前缀和也是不会TLE,所以随便搞
#include <iostream> #include <algorithm> using namespace std; struct water{ int time; int num; }a[1005]; int s[1005]; bool cmp(water a,water b){ return a.time<b.time; } int main(){ a[0].time=0; s[0]=0; int n; double ans=0; scanf("%d",&n); for(int i=1;i<=n;i++){ scanf("%d",&a[i].time); a[i].num=i; } sort(a+1,a+n+1,cmp); for(int i=1;i<=n;i++){ s[i]=s[i-1]+a[i].time; } for(int i=1;i<n;i++){ ans+=s[i]; } for(int i=1;i<=n;i++){ if(i==1) printf("%d",a[i].num); else printf(" %d",a[i].num); } printf("\n"); printf("%.2f\n",ans/n); }
总结,水题