数据结构:位图

概念:位图本质上是个数组,用来存放数组,数组中的元素用来判断某个元素是否存在于这个位图集合中,当元素存在时,对应位的值为1;当元素不存在时,对应位的值为0

我们先判断一下下面的例子:

给40亿个不重复的无符号整数,没排过序。给一个无符号整数,如何快速判断一个数是否在这40亿个数中。

解决方法:

1.遍历

2.先排序,然后二分查找

3.位图解决

我们使用比特位来表示某个数是否存在,一个字节包含包含8个比特位,无符号整数的范围是0到-1,所以需要/8个字节,相比于其他方法非常节省空间

实现主要有三个接口:set、reset、test

复制代码
 template<size_t N>
	class bitset
	{
	public:
		bitset()
		{
			_bs.resize(N / 32 + 1);//一个整形是32个比特位
		}
		void set(size_t x)
		{
			int i = x / 32;//第几位
			int j = x % 32;//对应位的比特位
			_bs[i] = _bs[i] | (1 << j);
		}
		void reset(size_t x)
		{
			int i = x / 32;
			int j = x % 32;
			_bs[i] = _bs[i] & ~(1 << j);
		}
		//x映射位为1返回假,
		//为0返回假
		bool test(size_t x)
		{
			int i = x / 32;
			int j = x % 32;
			return _bs[i] & (1 << j);
		}
	private:
		vector<int> _bs;
	};

那如果给100亿个整数呢,设计算法找出只出现一次的数字,100亿个数字,肯定会有重复出现的数字,所以我们需要稍微修改一下位图,加一位来表示出现次数

这时候再添加一个位图即可,00表示0次,01表示1次,10表示2次及以上

代码如下:

复制代码
	template<size_t N>
	class twobitset
	{
	public:
		void set(size_t x)
		{
			if (!_bs1.test(x) && !_bs2.test(x))
			{
				_bs1.set(x);
			}
			else if (_bs1.test(x) && !_bs2.test(x))
			{
				_bs1.reset(x);
				_bs2.set(x);
			}
			else if (_bs2.test(x) && !_bs1.test(x))
			{
				_bs1.set(x);
			}
		}
		int get_count(size_t x)
		{
			if (!_bs1.test(x) && !_bs2.test(x))
			{
				return 0;
			}
			else if (_bs1.test(x) && !_bs2.test(x))
			{
				return 1;
			}
			else if (_bs2.test(x) && !_bs1.test(x))
			{
				return 2;
			}
			else
			{
				return 3;
			}
		}
	private:
		bitset<N> _bs1;
		bitset<N> _bs2;
	};
相关推荐
奶黄小甜包36 分钟前
C语言零基础第18讲:自定义类型—结构体
c语言·数据结构·笔记·学习
想不明白的过度思考者41 分钟前
数据结构(排序篇)——七大排序算法奇幻之旅:从扑克牌到百亿数据的魔法整理术
数据结构·算法·排序算法
一支闲人1 小时前
C语言相关简单数据结构:双向链表
c语言·数据结构·链表·基础知识·适用于新手小白
姜不吃葱1 小时前
【力扣热题100】双指针—— 接雨水
数据结构·算法·leetcode·力扣热题100
拂晓银砾1 小时前
Java数据结构-队列
java·数据结构
John.Lewis2 小时前
数据结构初阶(19)外排序·文件归并排序的实现
c语言·数据结构·排序算法
John.Lewis2 小时前
数据结构初阶(16)排序算法——归并排序
c语言·数据结构·排序算法
tanyongxi662 小时前
C++ 特殊类设计与单例模式解析
java·开发语言·数据结构·c++·算法·单例模式
闪电麦坤953 小时前
数据结构:在二叉搜索树中插入元素(Insert in a BST)
数据结构·二叉树··二叉搜索树
闪电麦坤953 小时前
数据结构:用链式队列实现层序遍历 (Level-order Traversal)
数据结构··遍历