FEC之异或运算应用
2017-05-16 21:01
267 查看
话说为啥FEC需要异或( ^/⊕ )操作呢?
异或:xor
异或运算规则:
0 xor 0 = 0
0 xor 1 = 1
1 xor 0 = 1
1 xor 1 = 0
异或运算特性:
1). a xor a = 0
2). a xor 0 = a
3). (a xor b) xor c = a xor (b xor c)
4). IF a xor b = c THEN a xor c = b
异或的运算特性有两点很好的应用
查找
case 1:
一个数组,除了其中一个元素,其他元素都为空,如何找到这个元素?
对数组所有元素做异或的结果即为这个元素
利用了异或运算特性的1)、2)、3)
case 2:
给一个很大的数组,里面有两个数只出现过一次,其他数都出现过两次,把这两个数找出来?
这个case复杂一些,有兴趣的同学可以参考:一个百度的面试题目
校验&恢复
校验&恢复主要利用的了异或的第四条特性:IF a xor b = c THEN a xor c = b
一个很好的应用实例是RAID5
简单描述下:
使用3块磁盘(A、B、C)组成RAID5阵列,当用户写数据时,将数据分成两部分,分别写到磁盘A和磁盘B
A xor B的结果写到磁盘C
当读取A的数据时,通过B xor C可以对A的数据做校验
当A盘出错时,通过B xor C也可以恢复A盘的数据
RAID5的实现比上述的描述复杂多了,有兴趣的同学看下RAID5
异或:xor
异或运算规则:
0 xor 0 = 0
0 xor 1 = 1
1 xor 0 = 1
1 xor 1 = 0
异或运算特性:
1). a xor a = 0
2). a xor 0 = a
3). (a xor b) xor c = a xor (b xor c)
4). IF a xor b = c THEN a xor c = b
异或的运算特性有两点很好的应用
查找
case 1:
一个数组,除了其中一个元素,其他元素都为空,如何找到这个元素?
对数组所有元素做异或的结果即为这个元素
利用了异或运算特性的1)、2)、3)
case 2:
给一个很大的数组,里面有两个数只出现过一次,其他数都出现过两次,把这两个数找出来?
这个case复杂一些,有兴趣的同学可以参考:一个百度的面试题目
校验&恢复
校验&恢复主要利用的了异或的第四条特性:IF a xor b = c THEN a xor c = b
一个很好的应用实例是RAID5
简单描述下:
使用3块磁盘(A、B、C)组成RAID5阵列,当用户写数据时,将数据分成两部分,分别写到磁盘A和磁盘B
A xor B的结果写到磁盘C
当读取A的数据时,通过B xor C可以对A的数据做校验
当A盘出错时,通过B xor C也可以恢复A盘的数据
RAID5的实现比上述的描述复杂多了,有兴趣的同学看下RAID5
相关文章推荐
- FEC之异或运算应用
- 按位与 按位或 按位异或(位运算到底可以干什么,有些什么经典应用,以及如何用位运算优化你的程序)
- 位“异或”运算在变量交换中的应用及与位“或”的逻辑关系
- 异或^运算的应用
- 异或运算及其应用
- 与、或和异或在位运算中的应用
- 异或运算及其应用
- [PHP][位转换积累]之异或运算的简单加密应用
- C语言总结之异或运算的一些特性及巧妙应用
- 异或运算及其应用
- 异或运算的应用
- 异或运算及其应用
- 懂二进制(异或的应用;注意位运算的优先,以及与运算的结果,结果不一定是 1)---2015小米暑期实习笔试题
- 异或运算在算法编程题中的应用
- 异或运算的简单应用
- 异或运算及其应用
- 异或运算及其应用
- leetcode-371. Sum of Two Integers 位运算的应用,递归,按位异或a^b
- C语言总结之异或运算的一些特性及巧妙应用
- 与运算与异或运算的应用