C语言实现的bitmap位图代码分享
2014-08-28 10:09
946 查看
事实上,我们是用每一个 元素表示一个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; }
您可能感兴趣的文章:
相关文章推荐
- 三行代码实现gdi+ Bitmap对象导入资源文件位图
- Go语言实现位图排序(bitmap)
- Java语言实现基数排序代码分享
- Go语言实现机器大小端判断代码分享
- Android 拖拽效果实现代码分享 - ORIETech
- __FILE__,__LINE__,FUNCTION__实现代码跟踪调试(linux下c语言编程 )
- javascript实现WEB打印(用window.open()实现).不用安装任何控件.(含代码)分享
- 书上实现连接两个字符串的代码,分享下!
- PL/0语言编译程序整理实现:(7)、目标代码
- PL/0语言编译程序整理实现:(6)、代码类型
- (转)__FILE__,__LINE__,FUNCTION__实现代码跟踪调试(linux下c语言编程)
- 一段vc语言实现的发送http消息代码
- 分享下Java的几种注释语言吧!(代码生手顶下!)
- 汇编语言实现递归阶乘算法代码分析(8)
- PL/0语言编译程序整理实现:(8)、代码执行
- PL/0语言编译程序整理实现:(12)、测试代码
- 用C#语言实现http协议下的多线程文件传输(代码)(转)
- 根据Merge Sort原理, 自己实现的归并排序算法+详细注释+代码(C#,C/C++) [分享]
- __FILE__,__LINE__,FUNCTION__实现代码跟踪调试(linux下c语言编程)
- __FILE__,__LINE__,FUNCTION__实现代码跟踪调试(linux下c语言编程)