//法一(正常方法)
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
相关推荐
TracyCoder1238 小时前
LeetCode Hot100(15/100)——54. 螺旋矩阵开发者小天8 小时前
python中For Loop的用法flushmeteor8 小时前
JDK源码-基础类-String毕设源码-钟学长8 小时前
【开题答辩全过程】以 基于ssm的空中停车场管理系统为例,包含答辩的问题和答案不愿是过客9 小时前
java实战干货——长方法深递归u0109272719 小时前
C++中的策略模式变体2501_941837269 小时前
停车场车辆检测与识别系统-YOLOv26算法改进与应用分析小北方城市网10 小时前
Redis 分布式锁高可用实现:从原理到生产级落地探序基因10 小时前
单细胞Seurat数据结构修改分群信息六义义10 小时前
java基础十二