设为首页 加入收藏

TOP

位图算法 C语言
2015-01-22 20:57:12 来源: 作者: 【 】 浏览:13
Tags:位图 算法 语言
#include 
  
     

void set_bit(void *base, unsigned long n)  
{  
    unsigned long *m = (unsigned long*) base;
    unsigned long size = sizeof(unsigned long) * 8;
    m[ n / size ] |= 1UL << (n % size);
}  

void clear_bit(void *base, unsigned long n)  
{  
    unsigned long *m = (unsigned long*) base;
    unsigned long size = sizeof(unsigned long) * 8;
    m[ n / size ] &= ~(1UL << (n % size));
}  

int main()  
{  
    unsigned long value[2] = {0};
    set_bit(value, 0);  
    set_bit(value, 63);  
    printf("Set:\n");
    printf("0x%016lx, 0x%016lx\n", value[0], value[1]);  
    clear_bit(value, 0);  
    clear_bit(value, 63);  
    printf("Clear:\n");
    printf("0x%016lx, 0x%016lx\n", value[0], value[1]);  
    return 0;  
}  
  

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇C语言整数按照二进制逆序,输出逆.. 下一篇6个变态的C语言Hello World程序 ..

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: