有 n n n 个人在一个水龙头前排队接水,假如每个人接水的时间为 T i T_i Ti,请编程找出这 n n n 个人排队的一种顺序,使得 n n n 个人的平均等待时间最小。
第一行为一个整数 n n n。
第二行 n n n 个整数,第 i i i 个整数 T i T_i Ti 表示第 i i i 个人的等待时间 T i T_i Ti。
输出文件有两行,第一行为一种平均时间最短的排队顺序;第二行为这种排列方案下的平均等待时间(输出结果精确到小数点后两位)。
10
56 12 1 99 1000 234 33 55 99 812
3 2 7 8 1 4 9 6 10 5
291.90
具体代码如下啦,整体还是很简单的~
要让平均排队时间最小,就要让打水快的人往前排
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
int i, j, temp1, temp2;
double result = 0;
int t[] = new int[10000];
int l[] = new int[10000];
for (i = 0; i < n; i++) {
t[i] = sc.nextInt();
l[i] = i + 1;
}
for (i = 0; i < n; i++) {
for (j = i + 1; j < n; j++) {
if (t[i] > t[j]) {
temp1 = t[i];
t[i] = t[j];
t[j] = temp1;
temp2 = l[i];
l[i] = l[j];
l[j] = temp2;
}
}
}
for (i = 0; i < n; i++) {
result += t[i] * (n - i - 1);
}
for (i = 0; i < n; i++) {
System.out.print(l[i] + " ");
}
System.out.println();
System.out.println(String.format("%.2f", (result / n)));
}
}
一开始我将result的值设为了float型,输入样例时结果是正确的,但提交后发现还是有部分答案是错误的,红红一片,太可怕了,经过尝试,发现是精度出现了问题。
for (i = 0; i < n; i++) {
result += t[i] * (n - i - 1);
}