关于问号表达式,一般的用法就是用一次,比如:

return A > B ? A : B;

即,?前面的语句成立,返回:左边,否则返回:右边。

但是,既然这个表达这么简单了,一定是有其简单之大道的,比如:

int Max3( int A, int B, int C )
{ /* 返回3个整数中的最大值 */
    return A > B ? A > C ? A : C : B > C ? B : C;
}

直接懵了,是吧?

原来要比较三个数中的最大值,要一大段if条件,但是现在一行就解决了。

猛地一下看不懂,但是理解的了问号表达式的本质,?分开判断和结果,:分开两条分支,这样再来看,就很明朗了。

就是A > B?

是的话到A > C? 再判断;

不是的话到B > C?判断。

所以,编程的有趣就在于,逻辑其实都是一样,就看怎么把有限的工具用得更灵活巧妙了。