//法一(正常方法)
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
相关推荐
踩坑记录6 小时前
leetcode hot100 easy 101. 对称二叉树 递归 层序遍历 bfs2501_940315267 小时前
leetcode182动态口令(将字符的前几个元素放在字符串后面)老鼠只爱大米7 小时前
LeetCode经典算法面试题 #98:验证二叉搜索树(递归法、迭代法等五种实现方案详解)疯狂的喵13 小时前
C++编译期多态实现scx2013100413 小时前
20260129LCA总结2301_7657031413 小时前
C++中的协程编程m0_7487080513 小时前
实时数据压缩库小魏每天都学习13 小时前
【算法——c/c++]智码未来学堂14 小时前
探秘 C 语言算法之枚举:解锁解题新思路惊讶的猫14 小时前
探究StringBuilder和StringBuffer的线程安全问题