以前对这个问题也想过,但是始终想不到用什么原理去实现,现在整理如下
#define MAX(X,Y) (((X) - (Y)) & (1 << 31) ) ? (Y) : (X)
原理 : 最主要的是利用&运算的特点 ,首先 1 << 31 是将1左移31位变成了最左边一个 1 后面31个0,也就成了一个负数,然后利用X-Y的差与之做&(与)运算如果结果为 0 则证明 X-Y 大于0,也即 X > Y,否则X < Y。
还有一种不使用 ‘?:’ 三目运算符方法(ab为求绝对值函数)
#define MAX(X,Y) ( ((X+Y) + abs(X-Y))/2 )