How to implement a bitset in C?

前端 未结 7 2134
-上瘾入骨i
-上瘾入骨i 2020-11-30 04:42

I have been using the Bitset class in Java and I would like to do something similar in C. I suppose I would have to do it manually as most stuff in C. What would be an effic

7条回答
  •  失恋的感觉
    2020-11-30 05:00

    Nobody mentioned what the C FAQ recommends, which is a bunch of good-old-macros:

    #include      /* 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)
    

    (via http://c-faq.com/misc/bitsets.html)

提交回复
热议问题