基数排序是复杂度算法 P 或 NP 的一个示例



通过基数排序对向量进行排序的问题是复杂性算法P的一个例子?

我不知道它是NP完全还是只是NP。

void radixsort(int vector[], int size) {
    int i;
    int *b;
    int bigger= vector[0];
    int exp = 1;
    b = (int *)calloc(size, sizeof(int));
    for (i = 0; i < size; i++) {
        if (vetor[i] > bigger)
            size= vector[i];
    }
    while (bigger/exp > 0) {
        int bucket[10] = { 0 };
        for (i = 0; i < size; i++)
            bucket[(vetor[i] / exp) % 10]++;
        for (i = 1; i < 10; i++)
            bucket[i] += bucket[i - 1];
        for (i = size- 1; i >= 0; i--)
            b[--bucket[(vector[i] / exp) % 10]] = vector[i];
        for (i = 0; i < size; i++)
            vector[i] = b[i];
        exp *= 10;
    }
    free(b);
}

当然,它是在P!中,因为它的复杂性是多项式的。回答其他问题与这些复杂度类的关系有关。P 在 NP 中。因此,基数排序在NP中。由于我们不知道NP-完全问题的任何多项式agorithm,因此,我们不知道它是否在NP-Complete中,并且它与P = NP的已知问题有关?

最新更新