小心!#define max(a,b) a>b?a:b

时间:2023-03-08 22:39:46

今天做oj的时候,定义了两个宏:

//wrong code
#define max_2(a,b) a>b?a:b
#define max_3(a,b,c) (a>b?a:b)>c?(a>b?a:b):c

然后程序结果总是WA,仔仔细细检查程序的逻辑一遍又一遍,都快抓狂了,最后终于发现是我定义的两个宏有问题。改为如下就AC了:

#define max_2(a,b) (a>b?a:b)
#define max_3(a,b,c) ((a>b?a:b)>c?(a>b?a:b):c)

对的,就是差两个括号,没有括号,因为优先级不一样,造成运算顺序并不是我们预期的那样,运算结果错误。

下边是分析过程:

先上两段有问题的代码:

#include <iostream>
#define max_2(x,y) x>y?x:y
using namespace std; int main()
{
int a=max_2(,)+;
int b=max_2(,)+;
int c=max_2(,);
int d=max_2(,);
int e=(max_2(,)+);
cout<<a<<" "<<b<<endl;
cout<<c<<" "<<d<<endl;
cout<<e<<endl; return ;
}

运行结果:

小心!#define max(a,b) a>b?a:b

从程序中变量c、d可以发现,max_2(x,y)里不论x、y的顺序如何,max_2(x,y)能够返回正确的结果;

从程序中变量a、b可以发现,运算顺序跟max_2(x,y)里x、y的顺序有关,当x>y时,程序先将max_2(2,1)的结果赋给b,而不是加3之后再赋给b;

从程序中变量e可以发现,即使加了括号,也不能改变这种运算顺序。

另一段问题代码,如下图,编译都不能通过:

小心!#define max(a,b) a>b?a:b

所以,不要忘了关键的括号,不然害人不浅。