Java算法之位图的概念和实现详解

 更新时间:2023年10月26日 10:44:43   作者:CodeJiao  
这篇文章主要介绍了Java算法之位图的概念和实现详解,位图可以利用每一位来对应一个值,比如可以利用int类型的数去存储0~31这个集合的数字,如果该集合内的数字存在,则把对应的位设置位1默认为0,需要的朋友可以参考下

位图的介绍

位图可以利用每一位来对应一个值,比如可以利用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位图的概念和实现内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • SpringBoot2.4.2下使用Redis配置Lettuce的示例

    SpringBoot2.4.2下使用Redis配置Lettuce的示例

    这篇文章主要介绍了SpringBoot2.4.2下使用Redis配置Lettuce,Springboot2.4.2下默认使用的就是Lettuce而不是Jedis因此无需在依赖进行排除Jedis,本文给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧
    2022-01-01
  • java打印指定年月份的日历

    java打印指定年月份的日历

    这篇文章主要为大家详细介绍了java打印指定年、指定月份的日历,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-07-07
  • Spring Boot JPA中java 8 的应用实例

    Spring Boot JPA中java 8 的应用实例

    这篇文章主要介绍了Spring Boot JPA中java 8 的应用实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-02-02
  • Java中Array、List、Map相互转换的方法详解

    Java中Array、List、Map相互转换的方法详解

    这篇文章主要介绍了Java中Array、List、Map相互转换的方法详解,在实际项目开发中或者一些算法面试题目中经常需要用到Java中这三种类型的相互转换,比如对于一个整型数组中寻找一个整数与所给的一个整数值相同,需要的朋友可以参考下
    2023-08-08
  • JDK 1.8 安装配置教程(win7 64bit )

    JDK 1.8 安装配置教程(win7 64bit )

    这篇文章主要为大家详细介绍了win7 64bit下JDK 1.8 安装配置教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-08-08
  • mybatisplus 多表关联条件分页查询的实现

    mybatisplus 多表关联条件分页查询的实现

    本文主要介绍了mybatisplus 多表关联条件分页查询的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2025-01-01
  • Java读写Windows共享文件夹的方法实例

    Java读写Windows共享文件夹的方法实例

    本篇文章主要介绍了Java读写Windows共享文件夹的方法实例,具有一定的参考价值,有兴趣的同学可以了解一下。
    2016-11-11
  • 在controller中如何设置接收参数的默认值

    在controller中如何设置接收参数的默认值

    这篇文章主要介绍了在controller中如何设置接收参数的默认值,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-03-03
  • Java8中时区与不同历法处理指南

    Java8中时区与不同历法处理指南

    Java 8 的 java.time API 不仅修复了旧版日期时间 API 的设计缺陷,还提供了对时区和多历法的全面支持,下面小编就来讲讲具体的处理操作,有需要的可以了解下
    2025-04-04
  • Spring boot 使用JdbcTemplate访问数据库

    Spring boot 使用JdbcTemplate访问数据库

    SpringBoot 是为了简化 Spring 应用的创建、运行、调试、部署等一系列问题而诞生的产物。本文重点给大家介绍spring boot 使用JdbcTemplate访问数据库,需要的朋友可以参考下
    2018-05-05

最新评论