通过基数排序对向量进行排序的问题是复杂性算法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的已知问题有关?