如何实现简单的位数组

 我来答
万世沧桑之
2016-08-27 · 超过47用户采纳过TA的回答
知道答主
回答量:90
采纳率:0%
帮助的人:79.4万
展开全部
在 comp.lang.c 上面看到一则不错的 FAQ,《How can I implement sets or arrays of bits?》感觉很实用,仅仅使用了几个简单的宏就实现了一个基本的位数组(bitset)。

复制代码
#include <limits.h> /* for CHAR_BIT */

#define BITMASK(b) (1 << ((b) % CHAR_BIT))
#define BITSLOT(b) ((b) / CHAR_BIT)
#define BITSET(a, b) ((a)[BITSLOT(b)] |= BITMASK(b))
#define BITCLEAR(a, b) ((a)[BITSLOT(b)] &= ~BITMASK(b))
#define BITTEST(a, b) ((a)[BITSLOT(b)] & BITMASK(b))
#define BITNSLOTS(nb) ((nb + CHAR_BIT - 1) / CHAR_BIT)
复制代码
下面是一些简单的例子:

声明一个固定长度(50个bit)的位数组:
char bitarray[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];
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式