题目:
给你一个按递增顺序排序的数组 arr 和一个整数 k 。数组 arr 由 1 和若干 素数 组成,且其中所有整数互不相同。
对于每对满足 0 < i < j < arr.length 的 i 和 j ,可以得到分数 arr[i] / arr[j] 。
那么第 k 个最小的分数是多少呢? 以长度为 2 的整数数组返回你的答案, 这里 answer[0] == arr[i] 且 answer[1] == arr[j] 。
示例 1:
输入:arr = [1,2,3,5], k = 3
输出:[2,5]
解释:已构造好的分数,排序后如下所示:
1/5, 1/3, 2/5, 1/2, 3/5, 2/3
很明显第三个最小的分数是 2/5
示例 2:
输入:arr = [1,7], k = 1
输出:[1,7]
提示:
2 <= arr.length <= 1000
1 <= arr[i] <= 3 * 104
arr[0] == 1
arr[i] 是一个 素数 ,i > 0
arr 中的所有数字 互不相同 ,且按 严格递增 排序
1 <= k <= arr.length * (arr.length - 1) / 2
解法一:
static class Number {
BigDecimal number;
int[] numbers;
Number(BigDecimal number, int[] numbers) {
this.number = number;
this.numbers = numbers;
}
}
//注意点:输出的个数值而不是结果,系统会转成小数
//超时
public static int[] kthSmallestPrimeFraction(int[] arr, int k) {
List<Number> listNmbers = new ArrayList<Number>();
for (int i = 0; i < arr.length; i++) {
if (i <= arr.length - 2) {
for (int j = 0; j < arr.length; j++) {
if (i != j) {
BigDecimal bigDecimal = new BigDecimal((arr[i] * 1.0 / arr[j])).setScale(8, BigDecimal.ROUND_DOWN);
listNmbers.add(new Number(bigDecimal, new int[]{arr[i], arr[j]}));
}
}
}
}
for (int i = 0; i < listNmbers.size() - 1; i++) {
int min = i;
// 每轮需要比较的次数 N-i
for (int j = i + 1; j < listNmbers.size(); j++) {
if (listNmbers.get(j).number.compareTo(listNmbers.get(min).number) == -1) {
// 记录目前能找到的最小值元素的下标
min = j;
}
}
// 将找到的最小值和i位置所在的值进行交换
if (i != min) {
Number temp = listNmbers.get(i);
listNmbers.set(i, listNmbers.get(min));
listNmbers.set(min, temp);
}
}
return listNmbers.get(k-1).numbers;
}