【数据结构和算法】位图 BitMap

1. 位图结构的实现

/*** 位图数据类型 <br />* 位图以字节的一位为单位进行元素的操作,但是位运算以一个字节整体为运算单位,因此代码中以 bytes[index] 进行运算。* 位图元素的添加即找到相应的位置,将其置为1,实现时将该元素所在字节位与(1<<元素在字节所在位)求或即可;* 位图元素的删除即找到相应的位置,将其置为0,实现时将该元素所在字节位与(1<<元素在字节所在位)取反再求与即可;* 检查一个元素是否在位图中,实现时将该元素所在字节位与(1<<元素在字节所在位)求与后判断是否为0即可。**/
public class BitMap {private byte[] bytes;private int capacity;private static final int DEFAULT_CAPACITY = 32;public BitMap() {this(DEFAULT_CAPACITY);}public BitMap(int capacity) {this.capacity = capacity;this.bytes = new byte[(capacity >> 3) + 1];}/*** ADD** @param num 元素*/public void add(int num) {bytes[index(num)] |= (iterateByte(num));}/*** DELETE** @param num 元素*/public void delete(int num) {bytes[index(num)] &= (~iterateByte(num));}/*** 判断是否存在** @param num 元素* @return 如果存在返回 true,否则返回 false*/public boolean contains(int num) {return (bytes[index(num)] & iterateByte(num)) != 0;}/*** 计算 num/8** @param num 运算数* @return 索引*/private int index(int num) {return num >> 3;}/*** 获取元素字节所在位字节** @param num 运算数* @return 1 左移 num%8 位 的结果*/private int iterateByte(int num) {return 1 << (num & 0x07);}public byte[] getBytes() {return bytes;}public int getCapacity() {return capacity;}
}

2. 利用位图排序

public void sortByBitMap() {int[] arr = {4, 9, 2, 17, 3, 10};BitMap bitMap = new BitMap();for (int i : arr) {bitMap.add(i);}List<Integer> result = new ArrayList<>();byte[] bytes = bitMap.getBytes();for (int i = 0; i <bytes.length; i++) {for (int j = 0; j < 8; j++) {if ((bytes[i] & (1 << j)) == (1 << j)) {result.add((i << 3) + j);}}}System.out.println(result);
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/33046.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Redis_五种数据类型及操作命令

5.redis常用的五种数据类型 5.1 Redis String字符串 5.1.1 简介 String类型在redis中最常见的一种类型string类型是二制安全的&#xff0c;可以存放字符串、数值、json、图像数据value存储最大数据量是512M 5.1.2 常用命令 set < key>< value>&#xff1a;添加…

构造函数——初始化列表

初始化列表的引入。 #include<iostream> using namespace std;//栈类 typedef int DataType; class Stack { public://默认构造&#xff1a;Stack(size_t capacity ){cout << "Stack()" << endl;_array (DataType*)malloc(sizeof(DataType) * ca…

【golang】怎样判断一个变量的类型?

怎样判断一个变量的类型&#xff1f; package mainimport "fmt"var container []string{"zero", "one", "two"} func main() {container : map[int]string{0: "zero", 1: "one", 2: "two"}fmt.Printf…

享元模式(C++)

定义 运用共享技术有效地支持大量细粒度的对象。 使用场景 在软件系统采用纯粹对象方案的问题在于大量细粒度的对象会很快充斥在系统中&#xff0c;从而带来很高的运行时代价——主要指内存需求方面的代价。如何在避免大量细粒度对象问题的同时&#xff0c;让外部客户程序仍…

JavaWeb过滤器

目录 接口中的方法 init destroy doFilter 在web.xml中配置 作用 Filter也称之为过滤器&#xff0c;它是Servlet技术中最实用的技术&#xff0c;WEB开发人员通过 Filter技术&#xff0c;对web服务器管理的所有web资源&#xff1a;例如Servlet, 从而实现一些 特殊的功能。…

虚拟ip地址软件 怎么修改自己的网络ip地址

修改自己的网络IP地址在日常生活中&#xff0c;有时候我们可能需要修改自己的网络IP地址&#xff0c;这可能是由于网络问题、安全性考虑、建议使用第三方深度ip转换器切换ip地址。不用担心&#xff0c;下面将为大家介绍几种常见的修改网络IP地址的方法。 1. 通过重新连接网络&a…

128.【Maven】

Maven仓库 (一)、Maven 简介1.传统项目管理的缺点2.Maven是什么3.Maven的作用 (二)、Maven 的下载与安装1.下载与认识目录2.配置Maven的全局环境 (三)、Maven 的基础概念1.Maven 仓库(1).仓库分类 2. Maven 坐标3.Maven 本地仓库配置(1).改变默认的仓库地址(2).改变远程仓库地址…

mac电脑 node 基本操作命令

1. 查看node的版本 node -v2. 查看可安装的node版本 sudo npm view node versions3. 安装指定版本的node sudo n 18.9.04. 安装最新版本node sudo n latest5. 安装最新稳定版 sudo n stable6. 清楚node缓存 sudo npm cache clean -f7. 列举已经安装的node版本 n ls 8. 在…

代码随想录算法训练营第46天| 139.单词拆分 关于多重背包,你该了解这些! 背包问题总结篇!

今日学习的文章链接&#xff0c;或者视频链接 第九章 动态规划part08 自己看到题目的第一想法 看完代码随想录之后的想法 139: class Solution { public:bool wordBreak(string s, vector<string>& wordDict) {unordered_set<string> wordSet(wordDict.b…

【并发编程】无锁环形队列Disruptor并发框架使用

Disruptor 是苹国外厂本易公司LMAX开发的一个高件能列&#xff0c;研发的初夷是解决内存队列的延识问顾在性能测试中发现竟然与10操作处于同样的数量级)&#xff0c;基于Disruptor开发的系统单线程能支撑每秒600万订单&#xff0c;2010年在QCn演讲后&#xff0c;获得了业界关注…

c++11-14-17_内存管理(RAII)_多线程

文章目录 前言&#xff1a;什么是RAII&#xff1f;指针/智能指针&#xff1a;使用智能指针管理内存资源&#xff1a;unique_ptr的使用&#xff1a;自定义删除器&#xff1a; shared_ptr的使用&#xff1a;shared_ptr指向同一个对象的不同成员&#xff1a;自定义删除函数&#x…

期权定价模型系列【2】—期权的希腊字母计算及应用

本篇文章旨在介绍期权常见希腊字母的计算及应用 本专栏更多侧重于理论及文字方面的展示&#xff0c;文章具体的代码可以参考我的另一个专栏【期权量化】。 【期权量化】专栏有同名文章&#xff0c;并且给出了文章的具体代码。 专栏地址&#xff1a; http://t.csdn.cn/Y30Hk…

谈谈Java开发语言

目录 1.概念 2.特点 3.应用领域 4.就业情况 1.概念 Java是一种面向对象的编程语言&#xff0c;它由James Gosling和他的团队在1995年于Sun Microsystems&#xff08;现在是Oracle Corporation&#xff09;开发出来。Java的设计目标是让开发者能够编写一次代码&#xff0c;在…

Arcgis中POI找到建筑面内距离最近的标准地址通过模型构建器来实现

背景 之前写过一篇文章 Arcgis通过矢量建筑面找到POI对应的标准地址 这里面的大致思路跟本篇文章是类似的&#xff0c;不过上一篇文章有部分有瑕疵&#xff0c;就是在POI去找建筑面内的标准地址时&#xff0c;找到的虽然是建筑面内的&#xff0c;但是不一定是距离最近的&#…

登录界面中图片验证码的生成和校验

一、用pillpw生成图片验证码 1、安装pillow pip install pip install pillow2、下载字体 比如&#xff1a;Monaco.ttf 3、实现生成验证码的方法 该方法返回一个img ,可以把这个img图片保存到内存中&#xff0c;也可以以文件形式保存到磁盘&#xff0c;还返回了验证码的文字…

走出象牙塔:李郓梁的区块链实践之路丨对话MVP

如何从科研走向实践&#xff1f;李郓梁在社区找到了答案。 作为西安工业大学的硕士研究生&#xff0c;李郓梁从学校的实验室接触区块链技术。通过研读大量论文&#xff0c;李郓梁为区块链多中心化、不可篡改等前沿理论深深着迷&#xff0c;并选择将区块链作为主要研究方向&…

[前端系列第1弹]HTML入门教程:从零开始学习Web页面的基础知识

HTML是一种用于描述Web页面内容和结构的标记语言&#xff0c;它由一系列的标签&#xff08;tag&#xff09;组成&#xff0c;每个标签都有特定的含义和功能。HTML标签可以嵌套使用&#xff0c;形成一个树状的文档对象模型&#xff08;Document Object Model, DOM&#xff09;。…

使用gewe框架进行微信群组管理(一)

友情链接&#xff1a;geweapi.com 点击访问即可。 管理员操作 小提示&#xff1a; 添加、删除、转让多个wxid时仅限于添加/删除管理员&#xff0c;1添加 2删除 3转让 请求URL&#xff1a; http://域名地址/api/group/admin 请求方式&#xff1a; POST 请求头&#xff1a…

PlayCanvas初学问题汇总

pc.Application类型错误 // Expose prototype methods and create a default tween manager on the application (function () {// Add pc.Application#addTweenManager methodpc.Application.prototype.addTweenManager function () {this._tweenManager new pc.TweenManag…

C++实现一键关闭桌面

方法一&#xff1a; C关闭桌面,explorer.exe #include<Windows.h> #include <TlHelp32.h> #include"resource.h" #pragma warning(disable:4996) void taskkill(const char * name) {HANDLE info_handle CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS,…