Problem1560--排队接水 例题P389 输出略不同

1560: 排队接水 例题P389 输出略不同

[Creator : ]
Time Limit : 1.000 sec  Memory Limit : 128 MiB

Description

有n个人在一个水龙头前排队接水,假如每个人接水的时间为Ti,请编程找出这n个人排队的一种顺序,使得n个人的平均等待时间最小。
   

n<=1000

Ti<=10^6,Ti有可能有重复

当Ti重复时,按照输入顺序即可

如有5个人,时间分别为7  3  1  4  3,他们的排队顺序为第3人,第2,第5,第4,第1。在这个排序中,第2个和第5个的打水时间相等都是3,但因为第2先来,所以他先打水

Input

共两行
第一行为n;
第二行分别表示第1个人到第n个人每人的接水时间T1,T2,…,Tn,每个数据之间有1个空格。

Output

有两行
第一行为排队顺序,即1到n的一种排列;
第二行为这种排列方案下的平均等待时间(输出结果精确到小数点后两位)。注意:第x个人在打水时,他自己的等待时间也要计算入内。

Sample Input Copy

10
56 12 1 99 1000 234 33 55 99 812

Sample Output Copy

3 2 7 8 1 4 9 6 10 5
532.00

Source/Category

贪心