0

我正在实施快速选择算法以获取k数组中的第 th 个元素,但我被困在一个我不知道如何解决的地方。这是我的代码不起作用:

public static void main (String[] args) {
    int[] arr = new int[]{7,6,5,4,3,2,1}; 
    int k = 4;
    quickSort(arr, 0, arr.length - 1, k);
    return arr[k];
}

private static void quickSelect(int[] nums, int start, int end, int k) {
    if (start < end) {
        int partitionIndex = getPartitionIndex(nums, start, end);
        if (partitionIndex == k) {
            return;
        }
        quickSelect(nums, start, partitionIndex - 1, k);
        quickSelect(nums, partitionIndex + 1, end, k);
    }
}

private int getPartitionIndex(int[] nums, int start, int end) {
    int pivot = nums[end];
    int index = start;
    for (int i = start; i <= end; i++) {
        int current = nums[i];
        if (current < pivot) {
            swap(nums, index, i);
            index++;
        }
    }
    swap(nums, index, end);
    return index;
}

private void swap(int[] nums, int i, int j) {
    if (i == j) {
        return;
    }
    nums[i] = nums[i] ^ nums[j];
    nums[j] = nums[i] ^ nums[j];
    nums[i] = nums[i] ^ nums[j];
}

当然,如果我删除这些行:

        if (partitionIndex == k) {
            return;
        }

它变成快速排序并且工作正常。而且我理解为什么它不起作用,这是因为我从 0 到 k 的数组在我以上述条件返回时可能不会被排序。但是我无法找到正确的条件,我只对数组中的前 k 个元素进行排序而忽略其余的,所以我不做任何额外的工作。我在网上查看了一些实现并在上面花了一些时间,但无法弄清楚,所以寻求帮助。

4

1 回答 1

1

如果 k < partitionIndex,只检查左分区,否则只检查右分区。

        if (k < partitionIndex)
            quickSelect(nums, start, partitionIndex - 1, k);
        else
            quickSelect(nums, partitionIndex + 1, end, k);
于 2021-06-13T06:59:34.480 回答