//法一(正常方法)
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
相关推荐
Ray Liang21 小时前
用六边形架构与整洁架构对比是伪命题?颜酱21 小时前
理解二叉树最近公共祖先(LCA):从基础到变种解析Java水解21 小时前
Java 中间件:Dubbo 服务降级(Mock 机制)SimonKing1 天前
OpenCode AI辅助编程,不一样的编程思路,不写一行代码FastBean1 天前
Jackson View Extension Spring Boot StarterSeven971 天前
剑指offer-79、最⻓不含重复字符的⼦字符串皮皮林5511 天前
Java性能调优黑科技!1行代码实现毫秒级耗时追踪,效率飙升300%!冰_河1 天前
QPS从300到3100:我靠一行代码让接口性能暴涨10倍,系统性能原地起飞!!地平线开发者2 天前
SparseDrive 模型导出与性能优化实战董董灿是个攻城狮2 天前
大模型连载2:初步认识 tokenizer 的过程