int Max3( int A, int B, int C )
{ /* 返回3个整数中的最大值 */
return A > B ? A > C ? A : C : B > C ? B : C;
}
今天遇到这个神奇的return语句,首先我是懵逼的,好久没写代码,瞬间蒙了(哭晕在厕所)首先明确一点这个?:运算符是左结合的,之后就是可以一步步的去分析。
分析:第一个冒号和最近的?进行匹配,所以(A>C?A:C)是第一个部分,之后下一个冒号与最左边?进行匹配,最后一个:和B>C的?匹配
结果:return A > B ? (A > C ? A:C) : (B > C ? B:C);
其实这个条件运算符就相当于是if-else语句,所以可以改写成if-else语句
if(A>B)
if(A>C)
return A;
else
return C;
else
if(B>C)
return B;
else
return C;
很明显if-else代码量更多,但是这样更加简洁,可以让人看懂,不得不说条件运算符还是很有用的!