java - 中位数选择算法

标签 java algorithm selection median-of-medians

在过去的几天里,我一直在努力编写这个算法,但没有成功。该代码有效,并且大多数情况下它都会给我正确的结果,但在某些情况下会失败。例如,对于这个数组 {3, 8, 1, 9, 10, 7, 6, 2, 5, 4} 和 k = 6,它应该给我 6 作为结果,但它给我 7。有人可以帮助我吗?我不知道问题出在哪里。

这是代码:

class MOMSelect {

static int median(int a[], int i, int n) {
    if(i <= n)
        Arrays.sort(a, i, n);
    else
        Arrays.sort(a, n, i);
    return a[n/2];
}

static int medianOfMediansSelect(int a[], int left, int right, int k) {
    int n = right - left + 1;
    int i;
    int[] medians = new int[(n + 4) / 5];
    for (i = 0; i < n/5; i++) {
        medians[i] = median(a, left + i * 5, 5);
    }
    if (i*5 < n) {
        medians[i] = median(a,left + i * 5, n % 5);
        i++;
    }
    int medianOfMedians = (i == 1)? medians[i - 1]: median(medians, 0, medians.length);
    int pivotIndex = partition(a, left, right, medianOfMedians);
    if (pivotIndex == k - 1) {
        return a[pivotIndex];
    }
    else if (pivotIndex - left > k - 1) {
        return medianOfMediansSelect(a, left, pivotIndex - 1, k);
    }
    else {
        return medianOfMediansSelect(a, pivotIndex + 1, right, k);
    }
}

static void swap(int[] a, int i, int j) {
    int temp = a[i];
    a[i] = a[j];
    a[j] = temp;
}

static int partition(int[] a, int left, int right, int x) {
    int i;
    for (i = left; i < right; i++)
        if (a[i] == x)
            break;
    swap(a, i, right);
    i = left;
    for (int j = left; j <= right - 1; j++) {
        if(a[j] <= x) {
            swap(a, i, j);
            i++;
        }
    }
    swap(a, i, right);
    return i;
}

public static void main(String[] args) {
    int a[] = {3, 8, 1, 9, 10, 7, 6, 2, 5, 4};
    int n = a.length;
    int k = 1;
    System.out.println(medianOfMediansSelect(a, 0, n - 1, k));
}
}

先谢谢大家了

最佳答案

好的,我解决了。除了我对 Arrays.sort() 方法的不好理解之外,在 if 结构上还有一个愚蠢的错误,我在方法 medianOfMediansSelect()

上检查了 hubPosition 值

更准确地说,在这条线上

else if (pivotIndex - left > k - 1) {

我应该这样做

else if (pivotIndex > k - 1) {

关于java - 中位数选择算法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59788418/

相关文章:

javascript - 在 contentEditable 元素上按 Enter 键时插入 BR 或 P 标签的跨浏览器方式

java - DocumentBuilder 线程安全吗?

java - 如何跟踪另一个类的变量值

algorithm - 如何判断字符相似度?

iphone - ios:选择确定下一个屏幕

javascript - 浏览器页面中选定文本的坐标

java - SpringFramework 和 Hibernate 应用程序 HTTP 状态 404 Java

java - shutdownHooks RuntimePermission 的作用是什么?

algorithm - 如何切线连接N个相同直径的圆?

algorithm - 如何计算人与人之间的关系图?