//法一(正常方法)
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
相关推荐
郝学胜-神的一滴5 分钟前
Python中的“==“与“is“:深入解析与Vibe Coding时代的优化实践流云鹤16 分钟前
动态规划01abyyyyy12321 分钟前
oj题目练习有一个好名字23 分钟前
JAVA虚拟机-JVMSmartBrain25 分钟前
技术总结:VLLM部署Qwen3模型的详解weixin_4772716928 分钟前
第四正:关键(马王堆帛书《老子》20)玄〤30 分钟前
枚举问题的两大利器:深度优先搜索(DFS)与下一个排列(Next Permutation)算法详解(Java版本)(漫画解析)智者很聪明30 分钟前
数据结构之栈和队列weixin_4772716932 分钟前
第三正:结构(马王堆帛书《老子》2)uesowys33 分钟前
算法开发指导-数据结构-Tree