lzhenf

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

用bitmap方法,内存只需要 512M左右 

#include <stdio.h>
#include <memory.h>
#define BYTESIZE 8
long long bufferlen =500000000;
char *pBuffer = new char[bufferlen];

void setbit(char * p , int posi)
{
for ( int i = 0 ; i < posi / BYTESIZE ; i++)
{
p++;
}
*p = *p | (0x01 << (posi % BYTESIZE)) ;
}
int main()
{
memset(pBuffer , 0 , bufferlen);
int arr[] = { 23,12,11,67,89,14,33};
for ( int i = 0 ; i < 7 ; i++)
{
setbit(pBuffer,arr[i]);
}
for ( int i = 0 ; i < bufferlen ; i++)
{
for ( int j = 0 ; j < BYTESIZE ; j++)
if ( (*pBuffer & (0x01 << j)) == (0x01 << j) )
printf("%d" , (i )*BYTESIZE + j);
pBuffer++;
}
return 0;
}
posted on 2012-03-21 23:54  lzhenf  阅读(616)  评论(0编辑  收藏  举报