解题思路:
先说一下算法, 交换a,b:
方法一(不使用第三方参数)[此方法曾在面试中考过]
a=a+b; b=a-b; a=a-b;
方法二(传统方法):
t=a; a=b; b=t;
本题的难点肯定不在算法, 应该是宏函数!
带参宏定义的一般形式为:
#define 宏名(形参表) 字符串;
在字符串中含有各个形参。
带参宏调用的一般形式为:
#define y(a,b) t=a,a=b,b=t;
宏名(实参表),其中a,b就是实参,通过在主函数中输入,然后通过宏定义的预处理,也就是后面的字符串(t=a,a=b,b=t)来运算,在主函数中得到调用。
举个实例:C语言动态开辟内存空间
#define MALLOC(n, type) ( (type *) malloc((n)* sizeof(type))) 利用这个宏,我们就可以为任何类型分配一段我们指定的空间大小,并返回指向这段空间的指针。 我们可以观察一下这个宏确切的工作过程: int *ptr; ptr = MALLOC ( 5, int ); 将这宏展开以后的结果: ptr = (int *) malloc ( (5) * sizeof(int) );
注意事项:
\ 是换一行继续写。
参考代码:
//方法一:新型算法 #include <stdio.h> #define change(a,b) \ a=a+b;\ b=a-b;\ a=a-b; int main() { int a,b; scanf("%d%d",&a,&b); change(a,b); printf("%d %d",a,b); return 0; }
//方法二:传统方法学 #include <stdio.h> #define change(a,b) \ t=a;\ a=b;\ b=t; int main() { int a,b,t; scanf("%d%d",&a,&b); change(a,b); printf("%d %d",a,b); return 0; }
效果图:
0.0分
0 人评分