//法一(正常方法)
int main()
{
int a = 3;
int b = 5;
int tmp = 0;//临时变量
printf("before:a=%d b=%d\n", a, b);
tmp = a;
a = b;
b = tmp;
printf("after:a=%d b=%d\n", a, b);
return 0;
}
//法二(加减法) 有缺陷 a=a+b超出范围就可能出错(可能会溢出)
int main()
{
int a = 3;
int b = 5;
printf("before:a=%d b=%d\n", a, b);
a = a + b;
b = a - b;
a = a - b;
printf("after:a=%d b=%d\n", a, b);
return 0;
}
//法三(异或法)
int main()
{
int a = 3;
int b = 5;
printf("before:a=%d b=%d\n", a, b);
a = a ^ b;//a 011 b 101 异或结果为110
b - a ^ b;
a = a ^ b;
printf("after:a=%d b=%d\n", a, b);
return 0;
}
交换两个int变量的值,不能使用第三个变量。即a=3,b=5,交换之后a=5,b=3。
失落的香蕉2024-01-20 6:05
相关推荐
sali-tec5 小时前
C# 基于halcon的视觉工作流-章66 四目匹配小明说Java5 小时前
常见排序算法的实现45288655上山打老虎6 小时前
C++完美转发Seven976 小时前
查找算法行云流水20196 小时前
编程竞赛算法选择:理解时间复杂度提升解题效率毕设源码-朱学姐7 小时前
【开题答辩全过程】以 公务员考试在线测试系统为例,包含答辩的问题和答案serendipity_hky7 小时前
【SpringCloud | 第2篇】OpenFeign远程调用RwTo7 小时前
【源码】-Java线程池ThreadPoolSadSunset7 小时前
(15)抽象工厂模式(了解)兮动人7 小时前
EMT4J定制规则版:Java 8→17迁移兼容性检测与规则优化实战