题目:有 n 个人在一个水龙头前排队接水,假如每个人接水的时间为 t[i],请编程找出这 n 个人排队的一种顺序,使得 n 个人的平均等待时间最小。
- 1000ms
- 131072K
输入格式
第一行一个整数 n(1≤n≤1000),表示排队的人数。
第二行 n 个整数 t[i](1≤t[i]≤106),表示每个人接水的时间。
输出格式
第一行为一种排队顺序,即 1 到 n 的一种排列;
第二行为这种排列方案下的平均等待时间(输出结果精确到小数点后两位)。
如果两种方案的平均等待时间相同,输出字典序更小的方案。
输出时每行末尾的多余空格,不影响答案正确性
样例输入
6 18 10 20 14 14 13

该博客讨论了如何使用C++编程解决一个优化问题:如何安排n个人的接水顺序,以最小化平均等待时间。博客提供了输入输出格式,样例输入输出,并解释了应该让接水时间短的人先接水以减少整体等待时间。博主给出了AC代码实现。
最低0.47元/天 解锁文章
735

被折叠的 条评论
为什么被折叠?



