对于负数而言,求相反数就是求其绝对值,上篇博客已经给出了用位运算求绝对值的方法。这篇博客给出用位运算求正数的相反数的方法。我们知道,对于用源码表示的数中,如果一个正数和一个负数除符号位不同,其他位均相同的话,那么他们互为相反数。从这个规则可知,如果我们将一个正数的符号位取反,那么将得到这个数用原码表示的相反数。同时,我们知道计算机里面的数是用补码形式存储的,而且负数的补码是原码除符号位外其余位取反加1,那么我们可以通过将一个正数的所有位取反然后加1的方式得到它的相反数。代码如下所示:
int get_reverse_for_positive_number(int num) {
return ~num + 1;
}