Programming Tutorials and Interview Questions

Two integers have *opposite signs* if their most significant bits (msb) are different. The most significant bit (also the sign bit for a signed integer) of any negative number will always be 1, on the contrary it will always be 0 if the number is positive. Following that, if bitwise operator *exclusive OR* (XOR "^") is applied on two integers of opposite signs, the resultant number will be a negative one.
Because most significant bits of both numbers will not be the same and in that case XOR operation will produce 1 (as XOR operator results zero only when it is applied on 2 zeroes or 2 ones) that makes the resultant a negative number.

Hence, the result of bitwise exclusive OR applied on two integers will be less than zero, if numbers are of opposite signs.

Note that this solution of checking opposite signs of two numbers is for integers, because bitwise operators operate on `char`

and `int`

only.

*C program to check whether two integer variables have same or different sings.*

/* Write a C program to check if two integers have opposite signs. */ #include <stdio.h> int main() { int n1, n2; //declare two integers printf ("Enter two integer values: "); scanf ("%d%d", &n1, &n2); if ((n1 ^ n2) < 0) { printf ("Both numbers (%d, and %d) have opposite signs.\n", n1, n2); } else { printf ("Both numbers (%d, and %d) have same sign.\n", n1, n2); } return 0; }

Hope you have enjoyed reading C program for checking if two integers have opposite or same signs using bitwise operators. Please do write us if you have any suggestion/comment or come across any error on this page. Thanks for reading!

Rory visits a beekeeper in Manchester who is gluing wireless chips to his bees.

The new Apple's iOS has Persian keyboard. BBC Persian's Sam Farzaneh discusses why it is an important feature.

Ride-hailing app Uber is "not fit and proper" to operate in London, the transport regulator says.

×