//法一(正常方法)
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
相关推荐
高山上有一只小老虎21 小时前
JPA实现分页查询阿蒙Amon21 小时前
C#每日面试题-Task和ValueTask区别kaikaile199521 小时前
基于MATLAB的PSO-ELM(粒子群优化极限学习机)算法实现YuTaoShao21 小时前
【LeetCode 每日一题】1895. 最大的幻方——(解法二)前缀和优化Java程序员威哥21 小时前
【包教包会】SpringBoot依赖Jar指定位置打包:配置+原理+避坑全解析a程序小傲21 小时前
中国邮政Java面试被问:边缘计算的数据同步和计算卸载Java程序员威哥21 小时前
Java微服务可观测性实战:Prometheus+Grafana+SkyWalking全链路监控落地苦藤新鸡21 小时前
21.在有序的二位数组中用O(m+n)的算法找target毕设源码-邱学长21 小时前
【开题答辩全过程】以 面向警务应用的问答系统的设计与实现为例,包含答辩的问题和答案小尧嵌入式21 小时前
【Linux开发二】数字反转|除数累加|差分数组|vector插入和访问|小数四舍五入及向上取整|矩阵逆置|基础文件IO|深入文件IO