用异或交换两个变量的分析
来源:互联网 发布:教师网络研修平台 编辑:程序博客网 时间:2024/05/20 17:59
用异或交换两个变量,其实很简单,只要记住异或的特性:
设Y为一个二进制的bit位,
对于异或 ( xor ) 操作则有: Y xor 0 = Y ; Y xor 1 = ~Y (Y的非); Y xor Y = 0; ;
现在看一下,两个变量 A 、B交换的情形:
B = A xor B;
A = A xor B;
B = A xor B;
分析如下:
B = A xor B;
A = A xor B; // A = A xor B = A xor ( A xor B ) = A xor A xor B = (A xor A) xor B = 0 xor B = B; 即 A = B;
B = A xor B; // 此前, B = A xor B; A = B;
// 那么 B = A xor B = B xor ( A xor B ) = (A xor B ) xor B = A xor B xor B = A xor (B xor B ) = A xor 0 = A; 即 B = A;
可见,通过上面三个步骤,就实现了变量A、B的交换;
// 而且都是 A Xor B 操作, 而且中间语句的左端的变量不同于开始和结束语句的左端的变量,此外,开始和结束语句左端的变量是同一个变量!
其实,异或操作是一个非常有用的操作,在密码学中很多加密算法就是用了异或(xor)操作的这些特性来时实现加解密的。
- 用异或交换两个变量的分析
- 用异或来交换两个变量效率分析
- 用异或来交换两个变量是错误的
- 用异或来交换两个变量是错误的
- 用异或来交换两个变量是错误的
- 异或操作交换两个变量的值
- 使用异或运算交换两个变量的危险
- 应用位异或交换两个变量的值
- 使用异或运算对交换两个变量的数据
- 用异或来交换两个变量更耗时
- 两个变量异或法交换值
- 用异或来交换两个变量能提高速度是错误的
- 不允许创建临时变量,交换两个数的内容(用异或实现)
- 关于交换两个变量的不用第三个变量 异或的问题
- 不使用第三个变量交换两个变量的值之"异或"的实际应用
- 不使用临时变量交换两个变量的值(异或,加减,乘除)
- 不用变量交换两个int变量的值的分析
- 按位异或交换两个变量时的一个陷阱
- win7安装oracle 10g时发生“程序异常终止。发生内部错误”的提示
- 针对.NET的Scala交叉编译
- linux c sscanf和sprintf的简单用法与理解
- ExtJS中get、getDom、getCmp、getBody、getDoc使用 javascript[转] .
- div中的相对定位与绝对定位(转)
- 用异或交换两个变量的分析
- zend studio 出错重装
- AJAX原理
- 餐馆那些事之:接口实现分离
- android编程1:ip2id程序
- zoj 2971 Give Me the Number
- zoj 3479 Chinese Zodiac
- 浮点数
- poj 2153 Rank List