然后遍历这5个元素,首先第一个元素是4,那么就把4对应的位置为1(可以这样操作 p+(i/8)|(0×01
然后再处理第二个元素7,将第八位置为1,,接着再处理第三个元素,一直到最后处理完所有的元素,将相应的位置为1,这时候的内存的Bit位的状态如下:
最后遍历一遍Bit区域,将位置是1的对应的编号输出(2,3,4,5,7),这样就达到了排序的目的。
3.2 需要多个8bit空间的例子
假设需要排序或者查找的最大数MAX=10000000(这里MAX应该是最大的数而不是int数据的总数!),那么我们需要申请内存空间的大小为int a[1 + MAX/32],在内存中int占4个字节共32位。其中:a[0]在内存中占32为可以对应十进制数0-31,依次类推:
bitmap表为:
a[0]--------->0-31
a[1]--------->32-63
a[2]--------->64-95
a[3]--------->96-127
..........
要把一个整数N映射到Bit-Map中去,首先要确定把这个N Mapping到哪一个数组元素中去,即确定映射元素的index。我们用int类型的数组作为map的元素,这样我们就知道了一个元素能够表示的数字个数(这里是32)。于是N/32就可以知道我们需要映射的key了。所以余下来的那个N%32就是要映射到的位数。比如:N=65,65/32=2(-->对应在数组a中的下标为1,a[1]),65%32=1(--> 对应0-31的第1位),那么65的位置应该在a[1]的0-31中的第1位置。
4. 移位操作的实现
4.1 移位实现:求十进制数对应在数组a中的下标i
i = n>>K 等同于 n/(2^K)
int型数组,数组的每个元素都是int,int需要32bit的空间。所以先由十进制数n转换为与32的余可转化为对应在数组a中的下标。如十进制数0-31,都应该对应在a[0]中,比如n=24,那么 n/32=0,则24对应在数组a中的下标为0。又比如n=60,那么n/32=1,则60对应在数组a中的下标为1,同理可以计算0-N在数组a中的下标。
如果要求n在int型数组中的下标,那么就需要n/32,所以上面公式K=5。
Note: map的范围是[0, 原数组最大的数对应的2的整次方数-1]。
4.2 移位实现:求十进制数在数组元素a[i]中0-31的位置m
m = n & ((1 等同于 n%(2^K)
十进制数0-31就对应0-31,而32-63则对应也是0-31,即给定一个数n可以通过模32求得对应0-31中的数。如果要求n在a[i]中的0-31的具体位置,那么就需要n%32,所以上面公式K=5。
4.3 移位实现:设置int型a[i]的0-31中第m位的bit位为1
a[i] = a[i] | (1
利用移位0-31使得对应第m个bit位为1。如:将当前4对应的bit位置1的话,只需要1左移4位与B[0] | 即可。
Note: 1 p+(i/8)|(1
4.4 移位实现:设置int型a[i]的0-31中第k位的bit位为0
a[i] = a[i] & ~(1
5. Bit-map算法代码实现