一个关于宏使用惨痛的教训
rt,一个憨批错误
我,作为一个宏使用狂热爱好者,max()
函数当然用宏定义
#define MAX(A,B) ((A)>(B)?(A):(B))
于是,我在这道树剖题中大量使用了此宏,比如下面:
ans=MAX(ans, query(1, idx[topf[a]], idx[a]));
if(l<=mid) ans=MAX(ans, query(sl, l, r));
于是因为宏定义的复制,你的一次query(sl, l, r)
操作变成了两次,然后……然后就T爆了8个点
一下午一直都在试图找线段树、树剖的锅
又想起了上次ans=MAX(ans, ++mp[t])
也是这样的锅
所以,远离宏定义