淘宝面试题一个,等待答案解决方法
淘宝面试题一个,等待答案从 [1,1000] 这个集合中任意选取100个不重复的整数,将这100个数压缩到 N 个 bit
淘宝面试题一个,等待答案
从 [1,1000] 这个集合中任意选取100个不重复的整数,将这100个数压缩到 N 个 bit 位中存储,问:
1、N 的最小值是多少?
2、给出这个最小值对应的压缩存储算法。
原问如此,无更多信息,请勿追问。
[解决办法]
扫描,首比特肯定是标志位,如果为0,那么5比特之后又是一个标志位,如果为1,那么10比特之后又是一个标志位
[解决办法]
[解决办法]学习了,呵呵
[解决办法]不使用组合的方案,有一种简单可行的办法能将上限降到525位。
将1000分成125个分区,每个分区有8个数,用125位可以表示每个分区是否有数据。
由于分区大小为8,可以用3位表示区内的一个数,每个数要附加1位标识后面是否还有此分区的数,所以每个数的表示总共需要4位,100个数就是400位。