Java算法之位图的概念和实现详解
位图的介绍
位图可以利用每一位来对应一个值,比如可以利用int类型的数去存储0~31这个集合的数字。如果该集合内的数字存在,则把对应的位设置位1(默认为0)。

如果要存储的集合元素范围超过了32个,则可以用int数组去实现位图,第一个数组元素保存0~31的元素,第二个数组元素保存32~63的数组元素。
位图的好处就是可以节省大量的空间,缺点是实现比较复杂。
注意:
并不是说int类型的位图只可以存储0~31的集合元素,也可以存储例如5~36的元素,在存储的时候设置一下规则就行了,1位对应5,2位对应6,…32位对应36。
位图的实现
我们先把完整的实现代码放在这里,后面会分析里面的具体实现。
public class BitMap {
private final long[] bitMap;
/**
* 构造函数
*
* @param max 位图存储着 [0,max]的元素
*/
public BitMap(int max) {
bitMap = new long[(max + 64) >> 6];
}
/**
* 往位图里面添加元素
*
* @param num 待添加的元素
*/
public void add(int num) {
bitMap[num >> 6] |= (1L << (num & 63));
}
/**
* 删除位图里面的元素
*
* @param num 待删除的元素
*/
public void delete(int num) {
bitMap[num >> 6] &= ~(1L << (num & 63));
}
/**
* 观察目标元素num在位图中是存在
*
* @param num 目标元素
* @return 存在返回1,否则返回0
*/
public boolean contains(int num) {
return (bitMap[num >> 6] & (1L << (num & 63))) != 0;
}
}
构造函数
代码实现:
/**
* 构造函数
*
* @param max 位图存储着 [0,max]的元素
*/
public BitMap(int max) {
bitMap = new long[(max + 64) >> 6];
}
分析:

添加元素
代码实现:
/**
* 往位图里面添加元素
*
* @param num 待添加的元素
*/
public void add(int num) {
bitMap[num >> 6] |= (1L << (num & 63));
}
分析:

删除元素
代码实现:
/**
* 删除位图里面的元素
*
* @param num 待删除的元素
*/
public void delete(int num) {
bitMap[num >> 6] &= ~(1L << (num & 63));
}
分析:
删除元素与添加元素类似,只是需要把该位置元素设置为0,而不是1。这里使用&元素去实现。

判断元素是否存在
代码实现:
/**
* 观察目标元素num在位图中是存在
*
* @param num 目标元素
* @return 存在返回1,否则返回0
*/
public boolean contains(int num) {
return (bitMap[num >> 6] & (1L << (num & 63))) != 0;
}
分析:

到此这篇关于Java算法之位图的概念和实现详解的文章就介绍到这了,更多相关Java位图的概念和实现内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
在SpringBoot环境中使用Mockito进行单元测试的示例详解
Mockito是一个流行的Java mocking框架,它允许开发者以简单直观的方式创建和使用模拟对象(mocks),Mockito特别适用于在Spring Boot环境中进行单元测试,所以本文介绍了在SpringBoot环境中使用Mockito进行单元测试的示例,需要的朋友可以参考下2024-11-11
在SpringBoot中使用YourKit进行性能调优的教程详解
在应用程序的开发过程中,性能调优是一个重要的环节,在SpringBoot应用程序中,我们可以使用YourKit来进行性能调优,YourKit是一款非常强大的Java性能调优工具,在本文中,我们将介绍如何在 SpringBoot应用程序中使用YourKit进行性能调优2023-06-06
SpringIOC BeanDefinition的加载流程详解
这篇文章主要为大家介绍了SpringIOC BeanDefinition的加载流程详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2022-10-10


最新评论