C语言不创建中间变量交换2个数

使用异或实现;

‌C语言中的异或运算‌符合以下规律,

‌ 交换律‌:即a ^ b = b ^ a。

‌ 结合律‌:(a ^ b) ^ c = a ^ (b ^ c)。

‌ 自反性‌:对于任意操作数a,有a ^ a = 0。

‌ 零元素‌:对于任意操作数a,有a ^ 0 = a。

‌ 唯一性‌:对于任意操作数a,有a ^ a = 0和a ^ 0 = a。

可利用实现不创建中间变量交换2个数;

cpp 复制代码
void CYhswpView::OnDraw(CDC* pDC)
{
	CYhswpDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	// TODO: add draw code for native data here
	CString str1;

	int a = 99, b = 33;
	str1.Format("a=%d,  b=%d", a, b);
	pDC->TextOut(30, 30, str1);

	a = a ^ b;
	b = b ^ a;//b=b^ a^b=a
	a = a ^ b;//a=a^ a^b=b

	str1.Format("a=%d,  b=%d", a, b);
	pDC->TextOut(30, 90, str1);

}
相关推荐
ArturiaZ3 小时前
【day29】
数据结构·c++·算法
Stringzhua5 小时前
队列-优先队列【Queue3】
java·数据结构·队列
季明洵9 小时前
数据在内存中的存储
数据结构·算法·c
阿昭L9 小时前
AVL树及其计算
数据结构
云深处@10 小时前
【数据结构】树&&堆
数据结构
星火开发设计10 小时前
关联式容器:map 与 multimap 的键值对存储
java·开发语言·数据结构·c++·算法
散峰而望10 小时前
【算法竞赛】二叉树
开发语言·数据结构·c++·算法·深度优先·动态规划·宽度优先
Stringzhua11 小时前
队列-双端队列【Queue2】
java·数据结构·算法·队列
重生之后端学习11 小时前
994. 腐烂的橘子
java·开发语言·数据结构·后端·算法·深度优先
m0_5312371712 小时前
C语言-if/else,switch/case
c语言·数据结构·算法