//法一(正常方法)
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
相关推荐
ytttr8737 小时前
隐马尔可夫模型(HMM)MATLAB实现范例野生的码农8 小时前
码农的妇产科实习记录AlenTech8 小时前
160. 相交链表 - 力扣(LeetCode)点云SLAM8 小时前
凸优化(Convex Optimization)理论(1)会周易的程序员8 小时前
多模态AI 基于工业级编译技术的PLC数据结构解析与映射工具jz_ddk9 小时前
[学习] 卫星导航的码相位与载波相位计算毕设源码-赖学姐9 小时前
【开题答辩全过程】以 高校人才培养方案管理系统的设计与实现为例,包含答辩的问题和答案放荡不羁的野指针9 小时前
leetcode150题-动态规划sin_hielo9 小时前
leetcode 1161(BFS)一起努力啊~9 小时前
算法刷题-二分查找