//法一(正常方法)
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
相关推荐
Sunhen_Qiletian2 分钟前
YOLOv2算法详解(上篇):从经典到进化的目标检测之路QTreeY1235 分钟前
detr目标检测+deepsort/strongsort/bytetrack/botsort算法的多目标跟踪实现AiXed14 分钟前
PC微信协议之nid算法_Jimmy_32 分钟前
Nacos的三层缓存是什么朝新_1 小时前
【实战】动态 SQL + 统一 Result + 登录校验:图书管理系统(下)谈笑也风生1 小时前
经典算法题之子集(四)mit6.8241 小时前
划分dp+滑窗+前缀和|deque优化百***92021 小时前
java进阶1——JVM迦蓝叶2 小时前
RDF 与 RDFS:知识图谱推理的基石百锦再2 小时前
选择Rust的理由:从内存管理到抛弃抽象