鱼C论坛

 找回密码
 立即注册
查看: 2284|回复: 3

关于实现位数组的问题

[复制链接]
发表于 2019-5-17 17:13:27 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
编写一组函数,实现位数组。函数的原型应该如下:

void set_bit(char bit_array[],unsigned bit_number);
void clear_bit(char bit_array[],unsigned bit_number);
void assign_bit(char bit_array[],unsigned bit_number,int value);
void test_bit(char bit_array[],unsigned bit_number);
每个函数的第一个参数是个字符数组,用于实际存储所有的位。第二个参数用于标识需要访问的位。函数的调用者必须确保这个值不要太大,以至于超出数组的边界。第一个函数把指定的位设置为1,第二个函数则把指定的位清零。如果value的值为0,第三个函数把指定的位清0,否则设置为1。至于最后一个函数,如果参数中指定的位不是0,函数就返回真,否则返回假。

这串代码有什么用呢??(代码是在网上看到的)

  1. #define CHAR_BIT (sizeof(char)*8)
  2. void set_bit(char bit_array[],unsigned int bit_number)
  3. {
  4.     bit_array[bit_number/CHAR_BIT]|=1<<bit_number%CHAR_BIT;
  5. }
  6. void clear_bit(char bit_array[],unsigned int bit_number)
  7. {
  8.     bit_array[bit_number/CHAR_BIT]&=~(1<<bit_number%CHAR_BIT);
  9. }
  10. void assign_bit(char bit_array[],unsigned int bit_number,int value)
  11. {
  12.     if(value)
  13.         set_bit(bit_array,bit_number);
  14.     else
  15.         clear_bit(bit_array,bit_number);
  16. }
  17. int test_bit(char bit_array[],unsigned int bit_number)
  18. {
  19.     if(bit_array[bit_number/CHAR_BIT]&1<<bit_number%CHAR_BIT)
  20.         return 1;
  21.     else
  22.         return 0;
  23. }
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2019-5-17 18:29:36 | 显示全部楼层
其实就是bitset,节省空间啊
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-5-22 17:10:52 | 显示全部楼层
Croper 发表于 2019-5-17 18:29
其实就是bitset,节省空间啊

怎么说?具体是怎么使用的呢?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-5-23 13:16:17 | 显示全部楼层
1809228982 发表于 2019-5-22 17:10
怎么说?具体是怎么使用的呢?

自己百度,关键词搜索:C语言,位运算
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-25 20:38

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表