位图排序之bitMap实现

 位图排序通常用在特定的大数据量的场景下,如对给定的20亿条无重复整形数据进行排序,要求使用的内存不能超过265M。此时我们可以采用位存储的方式来对数据进行排序。

2000000000/8/1024/1024<256M
首先,申请一个20亿的bit数组,然后读取20亿的数据,找到当前读取的整数所在的bit的位置,将其置1,直到所有的数据都读完。

第二,遍历bit数组,如果当前位置的bit位为1,则将下标输出到文件,否则判断下一个是否为1。

public class BitMap {
	public static void main(String[] args) {
		BitMap bitMap = new BitMap(2000000000);
		bitMap.set(100);
		System.out.println(bitMap.test(100));
		System.out.println(bitMap.test(101));
		System.out.println(bitMap.test(0));

	}

	byte[] bytes;

	public BitMap(int length) {
		int size = (length >>> 3) + 1;
		bytes = new byte[size];
	}

	private int getIndex(int index) {
		return index >>> 3;
	}

	private int getOffset(int index) {
		return index & 7;
	}

	public void set(int index) {
		bytes[getIndex(index)] = (byte) (bytes[getIndex(index)] | (1 << getOffset(index)));
	}

	public boolean test(int index) {
		return (bytes[getIndex(index)] & (1 << getOffset(index))) != 0;
	}

}

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值