手机
当前位置:查字典教程网 >编程开发 >C语言 >C语言实现的bitmap位图代码分享
C语言实现的bitmap位图代码分享
摘要:事实上,我们是用每一个元素表示一个32位的二进制字符串,这样这个元素可以保留相邻32个号码是否存在的信息,数组范围就下降到10000000/...

事实上,我们是用每一个 元素表示一个32位的二进制字符串,这样这个元素可以保留相邻32个号码是否存在的信息,数组范围就下降到10000000/32了.例如对于号码 89256,由于89256 mod 32=2789…8,这样我们应该置a[2789]中32位字符串的第8位(从低位数起)为1.

#define WORD 32 #define SHIFT 5 ////移动5个位,左移则相当于乘以32,右移相当于除以32取整 #define MASK 0x1F //16进制下的31 #define N 10000000 int bitmap[1 + N / WORD]; /* * 置位函数——用"|"操作符,i&MASK相当于mod操作 * m mod n 运算,当n = 2的X次幂的时候,m mod n = m&(n-1) */ void set(int i) { bitmap[i >> SHIFT] |= (1 << (i & MASK)); } /* 清除位操作,用&~操作符 */ void clear(int i) { bitmap[i >> SHIFT] &= ~(1 << (i & MASK)); } /* 测试位操作用&操作符 */ int test(int i) { return bitmap[i >> SHIFT] & (1 << (i & MASK)); }

实现排序(不能重复):

int main(void) { FILE *in = fopen("in.txt", "r"); FILE *out = fopen("out.txt", "w"); if (in == NULL || out == NULL) { exit(-1); } int i = 0; int m; for (i = 0; i < N; i++) { clear(i); } while (!feof(in)) { fscanf(in, "%d", &m); printf("%d/n", m); set(m); } printf("abnother"); for (i = 0; i < N; i++) { if (test(i)) { printf("%d/n", i); fprintf(out, "%d/n", i); } } fclose(in); fclose(out); return EXIT_SUCCESS; }

【C语言实现的bitmap位图代码分享】相关文章:

C语言中字符串和数字的相互转换实现代码

c语言中if 语句的作用范围示例代码

c语言冒泡排序法代码

C语言栈顺序结构实现代码

c语言 汉诺塔算法代码

哈夫曼的c语言实现代码

C语言实现静态链表的方法

C语言小程序 数组操作示例代码

C语言中打印特殊图案的实现代码

C实现分子沉积模拟的示例代码

精品推荐
分类导航