Manipulação de bits

📚 Introdução

Todos os dados que são armazenados em um computador são representados por bits, que são 0s e 1s. Por exemplo, o número 5 é representado por 101 em binário, e o número 7 é representado por 111.

📌 Operadores binários

Operador |

O operador | é o operador de ou, ou OR. Ele retorna 1 se pelo menos um dos bits for 1, e 0 caso contrário.

OperaçãoResultado

0 | 0

0

0 | 1

1

1 | 0

1

1 | 1

1

Operador ^

O operador ^ é o operador de ou exclusivo, ou XOR. Ele retorna 1 se os bits forem diferentes, e 0 se forem iguais.

OperaçãoResultado

0 ^ 0

0

0 ^ 1

1

1 ^ 0

1

1 ^ 1

0

Operador &

O operador & é o operador de e, ou AND. Ele retorna 1 se os dois bits forem 1, e 0 caso contrário.

OperaçãoResultado

0 & 0

0

0 & 1

0

1 & 0

0

1 & 1

1

Operador ~

O operador ~ é o operador de negação, ou NOT. Ele inverte todos os bits.

OperaçãoResultado

~0

1

~1

0

Operador <<

O operador << é o operador de deslocamento à esquerda. Ele desloca todos os bits para a esquerda, e preenche os bits vazios com 0.

OperaçãoResultado

1 << 1

2

1 << 2

4

5 << 2

20

Operador >>

O operador >> é o operador de deslocamento à direita. Ele desloca todos os bits para a direita, e preenche os bits vazios com 0.

OperaçãoResultado

1 >> 1

0

4 >> 1

2

5 >> 2

1

Checar se um bit está ligado

Para checar se um bit é 1, podemos usar o operador & com uma máscara que tenha apenas o bit que queremos checar como 1.

Por exemplo, para checar se o terceiro bit de 5 é 1, podemos fazer:

5 & (1 << 2) != 0 # true (5 = 101 em binário)

Retornar o bit menos significativo

Basta retornar o valor and 1, pois 1 só tem o bit menos significativo como 1:

5 & 1 # 1

Contar o número de bits 1

Em python podemos usar a função bin para converter um número para binário, e depois podemos usar a função count para contar o número de bits 1:

bin(5).count('1') # 2

Ou, se seu python está na versão 3.10 ou maior, você pode usar:

int.bit_count(5) # 2

Checar se um número é potência de 2

Se o númerno não for 0, vemos se ele tem algum bit em comum com seu antecessor, pois se ele for uma potência de 2, digamos 2**i, o único bit ligado será o i, enquanto seu antecessor tem todos os bits menores que i iguais a 1, assim o and deles será 0.

x = 5
x & (x - 1) == 0 # false

Bits necessários para representar um número

Podemos ver quantos bits são necessários para representar um número da seguinte forma:

int.bit_length(5) # 3

Ligar um bit

Para ligar um bit, basta usar o operador | com uma máscara que tenha apenas o bit que queremos ligar como 1.

Por exemplo, para ligar o segundo bit de 5 como 1, podemos fazer:

x = 5 # 101 em binário
x |= (1 << 1) # 7 (111 em binário)

Desligar um bit

Primeiro garantimos que o bit está ligado, depois ele recebe ele mesmo xor a potência de 2 do bit que queremos desligar.

Por exemplo, para desligar o terceiro bit de 5, podemos fazer:

x = 5 # 101 em binário

x |= (1 << 2)
x ^= (1 << 2) # 1 (001 em binário)

🧑‍🏫 Exercícios

  • Exercício 2544 do Beecrowd, esse exercício pode ser resolvido de várias maneiras, mas saber manipular bits te faz ter menos dor de cabeça.

  • Exercício 1026 do Beecrowd, também é um ótimo exercício para praticar manipulação de bits.

Last updated