您的位置 首页 解答

怎么完成简略的位数组(bit array)

在complangc上面看到一则不错的FAQ,《HowcanIimplementsetsorarraysofbits?》感觉很实用,仅仅使用了几个简单的

在 comp.lang.c 上面看到一则不错的 FAQ,《How can I implement sets or arrays of bits?》感觉很有用,只是使用了几个简略的宏就完成了一个根本的位数组bitset)。

#include "limits.h"#defineBITMASK(b) (1 << ((b) % CHAR_BIT))#defineBITSLOT(b) ((b) / CHAR_BIT)#defineBITSET(a, b) ((a)[BITSLOT(b)] |= BITMASK(b))#defineBITCLEAR(a, b) ((a)[BITSLOT(b)] &= ~BITMASK(b))#defineBITTEST(a, b) ((a)[BITSLOT(b)] & BITMASK(b))#defineBITNSLOTS(nb) ((nb + CHAR_BIT - 1) / CHAR_BIT)

下面是一些简略的比如:

  • 声明一个固定长度(50个bit)的位数组:
charbitarray[BITNSLOTS(50)];
  • 设置位数组中的某一位:

BITSET(bitarray,23);
  • 检测某一位
if(BITTEST(bitarray,35)) ...
  • 求两个位数组的并集
for(i =0; i < BITNSLOTS(47); i++)array3[i]= array1[i] | array2[i];
  • 求两个位数组的交集
for(i =0; i < BITNSLOTS(47); i++)array3[i]= array1[i] & array2[i];

下面是一个完好的比如,使用Sieve of Eratosthenes算法求素数:

#include#include<string.h>#defineMAX 10000intmain(){charbitarray[BITNSLOTS(MAX)];inti, j;memset(bitarray,0, BITNSLOTS(MAX));for(i =2; i < MAX; i++){if(!BITTEST(bitarray, i)){printf("%d", i);for(j = i + i; j < MAX; j +=i)BITSET(bitarray, j);}}return0;}

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/changshang/jieda/257747.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部