//法一(正常方法)
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
相关推荐
zzb15805 小时前
RAG from Scratch-优化-querywuqingshun3141595 小时前
如何停止一个正在退出的线程卷福同学5 小时前
QClaw内测体验,能用微信指挥AI干活了sali-tec5 小时前
C# 基于OpenCv的视觉工作流-章34-投影向量xiaoye-duck5 小时前
《算法题讲解指南:递归,搜索与回溯算法--递归》--3.反转链表,4.两两交换链表中的节点,5.快速幂Eward-an6 小时前
【算法竞赛/大厂面试】盛最多水容器的最大面积解析山栀shanzhi6 小时前
归并排序(Merge Sort)原理与实现阿豪学编程6 小时前
LeetCode438: 字符串中所有字母异位词Trouvaille ~6 小时前
【递归、搜索与回溯】专题(七):FloodFill 算法——勇往直前的洪水灌溉地平线开发者6 小时前
征程 6P codec decoder sample