技术改变命运
分类: C/C++
2016-07-18 15:26:41
1.请定义一个宏,比较两个数a、b的大小,不能使用大于、小于、if语句
这个题目很早了,网上有很多讨论
思路很多,看到其中有一个思路是 ((a+b)+abs(a-b))/2 就可以得到其中的大数了
确实很精彩,用数学方法,不过其中用到了abs函数
如果把abs函数也自定义了就好了
说干就干
写一个
int abs(int x)
{
return (((x>>31)&1)?(~x+1):x) //?:不算是if语句吧}
解释一下
x>>31位,将符号位移到最右端(当前的int还是32位的....以前16,以后64或更高...)
考虑到如果是负数的话左边会补1而不是补0
屏蔽一下
(x>>32)&0x00000001
也就是(x>>32)&1
在C++里面,0为false,非0为true
当有符号(负数)时,条件为真,则应计算绝对值了,否则直接返回
对负数求相反数
首先要知道负数在计算机内部的表示是补码表示的
关于补码的知识,请查相关书籍,计算机相关课程应该介绍过了
取反+1得补码得相反数
(~x+1)
好了,将abs(x)替换到原式((a+b)+abs(a-b))/2
同时将a+b等都加上括号
得到最终得结果#define max(a,b) (((a)+(b))+(((((a)-(b))>>31)&1)?(~((a)-(b))+1):((a)-(b))))/2
#define max(a,b) (((a)+(b))+(((((a)-(b))>>31)&1)?(~((a)-(b))+1):((a)-(b))))/2