题目描述
给你一个文件,里面包含40亿个整数,写一个算法找出该文件中不包含的一个整数, 假设你有1GB内存可用。
如果你只有10MB的内存呢?
解题思路
对于40亿个整数,如果直接用int数组来表示的大约要用4010^84B=16GB,超出了内存要求,这里
我们可以用bitmap来解决,bitmap基本思想是一位表示一个整数,比如我们有6个数据:
1
7 3 1 5 6 4
假设bitmap容量为8,当插入7时 bit[7]=1,以此类推
bit[3]=1
bit[1]=1
bit[5]=1
……
bit[4]=1
这样我们查询5,只需要查看bit[5]==1侧存在,否则不存在。
这