Java - Большой О BitCount()?

Что такое Big O количества бит? Я не уверен, как метод работает, но я бы предположил, что это сделано в O(logn).

В частности, с этим кодом (где х = 4, у = 1):

return Integer.bitCount(x^y);

3 ответа

Решение

Учитывая его реализацию, метод состоит из шести операторов O(1), выполняемых последовательно, поэтому это O(1).

public static int bitCount(int i) {
    // HD, Figure 5-2
    i = i - ((i >>> 1) & 0x55555555);
    i = (i & 0x33333333) + ((i >>> 2) & 0x33333333);
    i = (i + (i >>> 4)) & 0x0f0f0f0f;
    i = i + (i >>> 8);
    i = i + (i >>> 16);
    return i & 0x3f;
}

Это O(1)Вот его реализация для JDK 1.5+:

public static int bitCount(int i) {
    i = i - ((i >>> 1) & 0x55555555);
    i = (i & 0x33333333) + ((i >>> 2) & 0x33333333);
    i = (i + (i >>> 4)) & 0x0f0f0f0f;
    i = i + (i >>> 8);
    i = i + (i >>> 16);
    return i & 0x3f;
}

Любой алгоритм, работающий с вводом ограниченного размера, имеет сложность.

работает с вводом ограниченного размера.

Следовательно bitCount иметь сложность O(1).

Другие вопросы по тегам