Java算法 -- 位图的概念和实现

版权声明:本文为CSDN博主「CodeJiao」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/I_r_o_n_M_a_n/article/details/125457236

  1. 位图的使用介绍
    位图可以利用每一位来对应一个值,比如可以利用int类型的数去存储0~31这个集合的数字。如果该集合内的数字存在,则把对应的位设置位1(默认为0)。
    在这里插入图片描述

    如果要存储的集合元素范围超过了32个,则可以用int数组去实现位图,第一个数组元素保存0~ 31的元素,第二个数组元素保存32~63的数组元素。

    位图的好处就是可以节省大量的空间,缺点是实现比较复杂。

    并不是说int类型的位图只可以存储031的集合元素,也可以存储例如536的元素,在存储的时候设置一下规则就行了,1位对应5,2位对应6,…32位对应36。

  2. 位图的实现

    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;
        }
    }
    
    1. 构造函数
     /**
     * 构造函数
     *
     * @param max 位图存储着 [0,max]的元素
     */
    public BitMap(int max) {
        bitMap = new long[(max + 64) >> 6];
    }
    
    

    在这里插入图片描述

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

    在这里插入图片描述
    5. 删除元素

        /**
         * 删除位图里面的元素
         *
         * @param num 待删除的元素
         */
        public void delete(int num) {
            bitMap[num >> 6] &= ~(1L << (num & 63));
        }
    
    

    在这里插入图片描述
    6. 判断元素是否存在

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

    在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值