El operador Tilde (~) también llamado operador NOT bit a bit, realiza el complemento de cualquier número binario como argumento. Si el operando NOT es un número decimal, lo convierte en binario y realiza la operación de complemento a uno.
Para calcular el complemento a uno, simplemente invierta todos los dígitos [0 -> 1] y [1 -> 0] Ej: 0101 = 5; ~ (0101) = 1010. Uso del operador de tilde: 1. Se utiliza en la operación de enmascaramiento. Enmascarar significa establecer y restablecer los valores dentro de cualquier registro. por ejemplo:
char mask ;
mask = 1 << 5 ;
Establecerá la máscara en un valor binario de 10000 y esta máscara se puede usar para verificar el valor de bit presente dentro de otra variable.
int a = 4;
int k = a&mask ; if the 5th bit is 1 , then k=1 otherwise k=0.
Esto se llama Enmascaramiento de bits. 2. Encontrar el equivalente binario de cualquier número usando propiedades de enmascaramiento.
#include<stdio.h>
void equi_bits(unsigned char);
int main()
{
unsigned char num = 10 ;
printf("\nDecimal %d is same as binary ", num);
equi_bits(num);
return 0;
}
void equi_bits(unsigned char n)
{
int i ;
unsigned char j , k ,mask ;
for( i = 7 ; i >= 0 ; i--)
{
j=i;
mask = 1 << j;
k = n&mask ; // Masking
k==0?printf("0"):printf("1");
}
}
Salida: el decimal 10 es igual que 00001010
Mi observación : para el rango máximo de cualquier tipo de datos, el complemento a uno proporciona el valor negativo disminuido en 1 a cualquier valor correspondiente. ej .:
~ 1 --------> -2
~ 2 ---------> -3
y así sucesivamente ... Le mostraré esta observación usando un pequeño fragmento de código
#include<stdio.h>
int main()
{
int a , b;
a=10;
b=~a; // b-----> -11
printf("%d\n",a+~b+1);// equivalent to a-b
return 0;
}
Output: 0
Nota: esto es válido solo para el rango de tipo de datos. significa que para el tipo de datos int, esta regla será aplicable solo para el valor del rango [-2,147,483,648 a 2,147,483,647].
Gracias ... Que esto te ayude