小心!#define max(a,b) a>b?a:b
今天做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(1,2)+3; int b=max_2(2,1)+3; int c=max_2(1,2); int d=max_2(2,1); int e=(max_2(2,1)+3); cout<<a<<" "<<b<<endl; cout<<c<<" "<<d<<endl; cout<<e<<endl; return 0; }
运行结果:
从程序中变量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可以发现,即使加了括号,也不能改变这种运算顺序。
另一段问题代码,如下图,编译都不能通过:
所以,不要忘了关键的括号,不然害人不浅。