40亿个不重复的数字排序

用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 阅读( ...) 评论( ...) 编辑 收藏

转载于:https://www.cnblogs.com/lzhenf/archive/2012/03/21/2410840.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值