#include <stdio.h>
#define MAX(x, y) (x > y ? x : y)
int a[] = {5, 3, 54, 565, 24, 75};
int max(int n)
{
//用递归的方式从前面开始比较a[]中数值
return n == 0 ? a[0] : MAX(a[n], max(n - 1));
}int main(void){int n = 5;int m = max(n);printf("the max number of the array is %d\n", m);return 0;}
比较a[]中的数值,并输出最大值。
ps:
不好意思,上面代码中注释写错了,上面注释是当MAX(x, y)为普通函数时的注释
上式中运用宏函数,所以情况不同。
return n == 0 ? a[0] : MAX(a[n], max(n - 1));
相当于
return 9 == 0 ? a[0] : MAX(a[9], (9 == 0 ? a[0] : MAX(a[8], 7 == 0 ? a[0] : MAX(a[7], ......)));
因为宏只是将实参替代形参,并不会有相应的计算,如 n - 1.
221

被折叠的 条评论
为什么被折叠?



