两数交换的三种方法分析

在函数中实现两数交换,在主函数中打印需要使用指针变量,否则改变的值无法传递到主函数

1,定义空变量的交换方式
#include<stdio.h>
void swop(int *p,int *q)   //定义交换函数
{
 int tmp;    //空变量
 tmp=*q;    //交换主体
 *q=*p;
 *p=tmp;
}

2,不使用第三变量的交换方式
void swop1(int *p,int *q)
{
 *p=*p+*q;    //利用运算实现两数交换
 *q=*p-*q;
 *p=*p-*q;
}



3,按位异或的交换方式
void swop2(int *p,int *q)
{
 *p=*p^*q;    //对两数进行三次按位异或,实现交换两数的目的
 *q=*p^*q;
 *p=*p^*q;
}
```*


主函数
int main()
{
 int a=10;
 int b=20;
 swop2(&a,&b);    //向函数传递数据的地址
 printf("%d %d",a,b);    //打印交换后的两数
 return 0;
}
```*总结
定义空变量的交换方式简单实用,并且不存在BUG,而其他两种方式在实现数
的倒序输出中,会出现交换失败的问题。


猜你喜欢

转载自blog.csdn.net/qq_43023994/article/details/88927883